diff options
| author | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-12-17 13:36:17 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-12-17 13:36:17 -0800 | 
| commit | 2cc3a8f6ac0fb1e6095a47001d31aadcf9722bde (patch) | |
| tree | afcc572acff2548cdabdfb0ec488508e1864daf1 /fs/nfs/getroot.c | |
| parent | 23afc5c67588c92a062b4828a97b119755dffb51 (diff) | |
| parent | 78f5815368837ae7e3a0d3709c9f95f74e4d8537 (diff) | |
Merge git://git.linux-nfs.org/pub/linux/nfs-2.6
* git://git.linux-nfs.org/pub/linux/nfs-2.6:
  MAINTAINERS: update the NFS CLIENT entry
  NFS: Fix an Oops in NFS unmount
  Revert "NFS: Ensure we return zero if applications attempt to write zero bytes"
  SUNRPC xprtrdma: fix XDR tail buf marshalling for all ops
  NFSv2/v3: Fix a memory leak when using -onolock
  NFS: Fix NFS mountpoint crossing...
Diffstat (limited to 'fs/nfs/getroot.c')
| -rw-r--r-- | fs/nfs/getroot.c | 11 | 
1 files changed, 11 insertions, 0 deletions
diff --git a/fs/nfs/getroot.c b/fs/nfs/getroot.c index 0ee43843f4e..e6242cdbaf9 100644 --- a/fs/nfs/getroot.c +++ b/fs/nfs/getroot.c @@ -57,6 +57,17 @@ static int nfs_superblock_set_dummy_root(struct super_block *sb, struct inode *i  		}  		/* Circumvent igrab(): we know the inode is not being freed */  		atomic_inc(&inode->i_count); +		/* +		 * Ensure that this dentry is invisible to d_find_alias(). +		 * Otherwise, it may be spliced into the tree by +		 * d_materialise_unique if a parent directory from the same +		 * filesystem gets mounted at a later time. +		 * This again causes shrink_dcache_for_umount_subtree() to +		 * Oops, since the test for IS_ROOT() will fail. +		 */ +		spin_lock(&dcache_lock); +		list_del_init(&sb->s_root->d_alias); +		spin_unlock(&dcache_lock);  	}  	return 0;  }  | 
