Commit 31d7dc1b authored by Trond Myklebust's avatar Trond Myklebust

NFSv4: Optimizing away the case of negative dentries in

   nfs_open_revalidate() avoids several atomicity problems.
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@fys.uio.no>
parent 98ac02aa
...@@ -850,22 +850,22 @@ static int nfs_open_revalidate(struct dentry *dentry, struct nameidata *nd) ...@@ -850,22 +850,22 @@ static int nfs_open_revalidate(struct dentry *dentry, struct nameidata *nd)
unsigned long verifier; unsigned long verifier;
int openflags, ret = 0; int openflags, ret = 0;
/* NFS only supports OPEN for regular files */
if (inode && !S_ISREG(inode->i_mode))
goto no_open;
parent = dget_parent(dentry); parent = dget_parent(dentry);
dir = parent->d_inode; dir = parent->d_inode;
if (!is_atomic_open(dir, nd)) if (!is_atomic_open(dir, nd))
goto no_open; goto no_open;
openflags = nd->intent.open.flags; /* We can't create new files in nfs_open_revalidate(), so we
if (openflags & O_CREAT) { * optimize away revalidation of negative dentries.
/* If this is a negative dentry, just drop it */ */
if (!inode) if (inode == NULL)
goto out; goto out;
/* If this is exclusive open, just revalidate */ /* NFS only supports OPEN on regular files */
if (openflags & O_EXCL) if (!S_ISREG(inode->i_mode))
goto no_open;
openflags = nd->intent.open.flags;
/* We cannot do exclusive creation on a positive dentry */
if ((openflags & (O_CREAT|O_EXCL)) == (O_CREAT|O_EXCL))
goto no_open; goto no_open;
}
/* We can't create new files, or truncate existing ones here */ /* We can't create new files, or truncate existing ones here */
openflags &= ~(O_CREAT|O_TRUNC); openflags &= ~(O_CREAT|O_TRUNC);
......
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