Commit 6fc06ef9 authored by Trond Myklebust's avatar Trond Myklebust

NFS: Fix dentry refcount accounting error which causes unnecessary

 sillyrenames when renaming to an existing file.
Signed-off-by: default avatarGreg Banks <gnb@melbourne.sgi.com>
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@fys.uio.no>
parent 07e9eb2b
...@@ -1382,7 +1382,7 @@ static int nfs_rename(struct inode *old_dir, struct dentry *old_dentry, ...@@ -1382,7 +1382,7 @@ static int nfs_rename(struct inode *old_dir, struct dentry *old_dentry,
goto go_ahead; goto go_ahead;
if (S_ISDIR(new_inode->i_mode)) if (S_ISDIR(new_inode->i_mode))
goto out; goto out;
else if (atomic_read(&new_dentry->d_count) > 1) { else if (atomic_read(&new_dentry->d_count) > 2) {
int err; int err;
/* copy the target dentry's name */ /* copy the target dentry's name */
dentry = d_alloc(new_dentry->d_parent, dentry = d_alloc(new_dentry->d_parent,
...@@ -1397,10 +1397,8 @@ static int nfs_rename(struct inode *old_dir, struct dentry *old_dentry, ...@@ -1397,10 +1397,8 @@ static int nfs_rename(struct inode *old_dir, struct dentry *old_dentry,
new_inode = NULL; new_inode = NULL;
/* instantiate the replacement target */ /* instantiate the replacement target */
d_instantiate(new_dentry, NULL); d_instantiate(new_dentry, NULL);
} } else if (atomic_read(&new_dentry->d_count) > 1) {
/* dentry still busy? */ /* dentry still busy? */
if (atomic_read(&new_dentry->d_count) > 1) {
#ifdef NFS_PARANOIA #ifdef NFS_PARANOIA
printk("nfs_rename: target %s/%s busy, d_count=%d\n", printk("nfs_rename: target %s/%s busy, d_count=%d\n",
new_dentry->d_parent->d_name.name, new_dentry->d_parent->d_name.name,
......
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