diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2011-07-17 10:52:14 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2011-07-20 20:48:02 -0400 |
commit | 4513d899c418ff69052420e29e354e4c64b3ef76 (patch) | |
tree | ffe11084d28c4a3d7b4eaa745748539c2eff2fb4 | |
parent | 6c673ab393bc18e8bff729cd04cf384d15e72a04 (diff) | |
download | linux-4513d899c418ff69052420e29e354e4c64b3ef76.tar.gz linux-4513d899c418ff69052420e29e354e4c64b3ef76.tar.bz2 linux-4513d899c418ff69052420e29e354e4c64b3ef76.zip |
switch d_add_ci() to d_splice_alias() in "found negative" case as well
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r-- | fs/dcache.c | 24 |
1 files changed, 5 insertions, 19 deletions
diff --git a/fs/dcache.c b/fs/dcache.c index 2762804a140d..d1d6b3349ec7 100644 --- a/fs/dcache.c +++ b/fs/dcache.c @@ -1652,26 +1652,12 @@ struct dentry *d_add_ci(struct dentry *dentry, struct inode *inode, * Negative dentry: instantiate it unless the inode is a directory and * already has a dentry. */ - spin_lock(&inode->i_lock); - if (!S_ISDIR(inode->i_mode) || list_empty(&inode->i_dentry)) { - __d_instantiate(found, inode); - spin_unlock(&inode->i_lock); - security_d_instantiate(found, inode); - return found; + new = d_splice_alias(inode, found); + if (new) { + dput(found); + found = new; } - - /* - * In case a directory already has a (disconnected) entry grab a - * reference to it, move it in place and use it. - */ - new = list_entry(inode->i_dentry.next, struct dentry, d_alias); - __dget(new); - spin_unlock(&inode->i_lock); - security_d_instantiate(found, inode); - d_move(new, found); - iput(inode); - dput(found); - return new; + return found; err_out: iput(inode); |