]> err.no Git - linux-2.6/commitdiff
[AFS]: Handle multiple mounts of an AFS superblock correctly.
authorDavid Howells <dhowells@redhat.com>
Thu, 26 Apr 2007 22:56:24 +0000 (15:56 -0700)
committerDavid S. Miller <davem@davemloft.net>
Thu, 26 Apr 2007 22:56:24 +0000 (15:56 -0700)
Handle multiple mounts of an AFS superblock correctly, checking to see
whether the superblock is already initialised after calling sget()
rather than just unconditionally stamping all over it.

Also delete the "silent" parameter to afs_fill_super() as it's not
used and can, in any case, be obtained from sb->s_flags.

Signed-off-by: David Howells <dhowells@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
fs/afs/super.c

index efc4fe69f4f010693c0ff54607d1639d398dd7cd..77e68759788f3a516809061b532dfdcd48a84e5d 100644 (file)
@@ -212,7 +212,7 @@ static int afs_test_super(struct super_block *sb, void *data)
 /*
  * fill in the superblock
  */
-static int afs_fill_super(struct super_block *sb, void *data, int silent)
+static int afs_fill_super(struct super_block *sb, void *data)
 {
        struct afs_mount_params *params = data;
        struct afs_super_info *as = NULL;
@@ -319,17 +319,23 @@ static int afs_get_sb(struct file_system_type *fs_type,
                goto error;
        }
 
-       sb->s_flags = flags;
-
-       ret = afs_fill_super(sb, &params, flags & MS_SILENT ? 1 : 0);
-       if (ret < 0) {
-               up_write(&sb->s_umount);
-               deactivate_super(sb);
-               goto error;
+       if (!sb->s_root) {
+               /* initial superblock/root creation */
+               _debug("create");
+               sb->s_flags = flags;
+               ret = afs_fill_super(sb, &params);
+               if (ret < 0) {
+                       up_write(&sb->s_umount);
+                       deactivate_super(sb);
+                       goto error;
+               }
+               sb->s_flags |= MS_ACTIVE;
+       } else {
+               _debug("reuse");
+               ASSERTCMP(sb->s_flags, &, MS_ACTIVE);
        }
-       sb->s_flags |= MS_ACTIVE;
-       simple_set_mnt(mnt, sb);
 
+       simple_set_mnt(mnt, sb);
        afs_put_volume(params.volume);
        afs_put_cell(params.default_cell);
        _leave(" = 0 [%p]", sb);