Commit 0f899fb7 authored by Trond Myklebust's avatar Trond Myklebust Committed by Chris Wright

[PATCH] NFS: nfs_lookup - don't hash dentry when optimising away the lookup

If the open intents tell us that a given lookup is going to result in a,
exclusive create, we currently optimize away the lookup call itself. The
reason is that the lookup would not be atomic with the create RPC call, so
why do it in the first place?

A problem occurs, however, if the VFS aborts the exclusive create operation
after the lookup, but before the call to create the file/directory: in this
case we will end up with a hashed negative dentry in the dcache that has
never been looked up.
Fix this by only actually hashing the dentry once the create operation has
been successfully completed.
Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
Signed-off-by: default avatarChris Wright <chrisw@sous-sol.org>
parent d940c78f
...@@ -902,9 +902,15 @@ static struct dentry *nfs_lookup(struct inode *dir, struct dentry * dentry, stru ...@@ -902,9 +902,15 @@ static struct dentry *nfs_lookup(struct inode *dir, struct dentry * dentry, stru
lock_kernel(); lock_kernel();
/* If we're doing an exclusive create, optimize away the lookup */ /*
if (nfs_is_exclusive_create(dir, nd)) * If we're doing an exclusive create, optimize away the lookup
goto no_entry; * but don't hash the dentry.
*/
if (nfs_is_exclusive_create(dir, nd)) {
d_instantiate(dentry, NULL);
res = NULL;
goto out_unlock;
}
error = NFS_PROTO(dir)->lookup(dir, &dentry->d_name, &fhandle, &fattr); error = NFS_PROTO(dir)->lookup(dir, &dentry->d_name, &fhandle, &fattr);
if (error == -ENOENT) if (error == -ENOENT)
...@@ -1156,6 +1162,8 @@ int nfs_instantiate(struct dentry *dentry, struct nfs_fh *fhandle, ...@@ -1156,6 +1162,8 @@ int nfs_instantiate(struct dentry *dentry, struct nfs_fh *fhandle,
if (IS_ERR(inode)) if (IS_ERR(inode))
goto out_err; goto out_err;
d_instantiate(dentry, inode); d_instantiate(dentry, inode);
if (d_unhashed(dentry))
d_rehash(dentry);
return 0; return 0;
out_err: out_err:
d_drop(dentry); d_drop(dentry);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment