From: Trond Myklebust Date: Mon, 15 Jan 2007 18:56:29 +0000 (-0500) Subject: NFS: Fix a readdir/lookup inefficiency. X-Git-Tag: v2.6.21-rc1~297 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=df1d5d23d3a1a713c69b0f9ec67c59aeca3ce6b3;p=linux-2.6-omap-h63xx.git NFS: Fix a readdir/lookup inefficiency. Make sure that nfs_readdir_lookup() handles negative dentries correctly. If d_lookup() returns a negative dentry, then we need to d_drop() that since readdir shows that it should be positive. Signed-off-by: Trond Myklebust --- diff --git a/fs/nfs/dir.c b/fs/nfs/dir.c index bd269d26882..db29c7fa962 100644 --- a/fs/nfs/dir.c +++ b/fs/nfs/dir.c @@ -1123,8 +1123,14 @@ static struct dentry *nfs_readdir_lookup(nfs_readdir_descriptor_t *desc) } name.hash = full_name_hash(name.name, name.len); dentry = d_lookup(parent, &name); - if (dentry != NULL) - return dentry; + if (dentry != NULL) { + /* Is this a positive dentry? */ + if (dentry->d_inode != NULL) + return dentry; + /* No, so d_drop to allow one to be created */ + d_drop(dentry); + dput(dentry); + } if (!desc->plus || !(entry->fattr->valid & NFS_ATTR_FATTR)) return NULL; /* Note: caller is already holding the dir->i_mutex! */