forked from Minki/linux
ncpfs: don't bother with EBUSY on removal of busy directories
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
5faf153ebf
commit
338b2f5749
@ -1123,17 +1123,6 @@ static int ncp_rename(struct inode *old_dir, struct dentry *old_dentry,
|
||||
old_dentry->d_parent->d_name.name, old_dentry->d_name.name,
|
||||
new_dentry->d_parent->d_name.name, new_dentry->d_name.name);
|
||||
|
||||
if (new_dentry->d_inode && S_ISDIR(new_dentry->d_inode->i_mode)) {
|
||||
/*
|
||||
* fail with EBUSY if there are still references to this
|
||||
* directory.
|
||||
*/
|
||||
dentry_unhash(new_dentry);
|
||||
error = -EBUSY;
|
||||
if (!d_unhashed(new_dentry))
|
||||
goto out;
|
||||
}
|
||||
|
||||
ncp_age_dentry(server, old_dentry);
|
||||
ncp_age_dentry(server, new_dentry);
|
||||
|
||||
|
@ -891,6 +891,10 @@ int ncp_notify_change(struct dentry *dentry, struct iattr *attr)
|
||||
if (!server) /* How this could happen? */
|
||||
goto out;
|
||||
|
||||
result = -EPERM;
|
||||
if (IS_DEADDIR(dentry->d_inode))
|
||||
goto out;
|
||||
|
||||
/* ageing the dentry to force validation */
|
||||
ncp_age_dentry(server, dentry);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user