aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
Diffstat (limited to 'fs')
-rw-r--r--fs/dcache.c13
1 files changed, 5 insertions, 8 deletions
diff --git a/fs/dcache.c b/fs/dcache.c
index 63d556c0e698..5c5f3bd9af5f 100644
--- a/fs/dcache.c
+++ b/fs/dcache.c
@@ -731,8 +731,6 @@ EXPORT_SYMBOL(dget_parent);
731/** 731/**
732 * d_find_alias - grab a hashed alias of inode 732 * d_find_alias - grab a hashed alias of inode
733 * @inode: inode in question 733 * @inode: inode in question
734 * @want_discon: flag, used by d_splice_alias, to request
735 * that only a DISCONNECTED alias be returned.
736 * 734 *
737 * If inode has a hashed alias, or is a directory and has any alias, 735 * If inode has a hashed alias, or is a directory and has any alias,
738 * acquire the reference to alias and return it. Otherwise return NULL. 736 * acquire the reference to alias and return it. Otherwise return NULL.
@@ -741,10 +739,9 @@ EXPORT_SYMBOL(dget_parent);
741 * of a filesystem. 739 * of a filesystem.
742 * 740 *
743 * If the inode has an IS_ROOT, DCACHE_DISCONNECTED alias, then prefer 741 * If the inode has an IS_ROOT, DCACHE_DISCONNECTED alias, then prefer
744 * any other hashed alias over that one unless @want_discon is set, 742 * any other hashed alias over that one.
745 * in which case only return an IS_ROOT, DCACHE_DISCONNECTED alias.
746 */ 743 */
747static struct dentry *__d_find_alias(struct inode *inode, int want_discon) 744static struct dentry *__d_find_alias(struct inode *inode)
748{ 745{
749 struct dentry *alias, *discon_alias; 746 struct dentry *alias, *discon_alias;
750 747
@@ -756,7 +753,7 @@ again:
756 if (IS_ROOT(alias) && 753 if (IS_ROOT(alias) &&
757 (alias->d_flags & DCACHE_DISCONNECTED)) { 754 (alias->d_flags & DCACHE_DISCONNECTED)) {
758 discon_alias = alias; 755 discon_alias = alias;
759 } else if (!want_discon) { 756 } else {
760 __dget_dlock(alias); 757 __dget_dlock(alias);
761 spin_unlock(&alias->d_lock); 758 spin_unlock(&alias->d_lock);
762 return alias; 759 return alias;
@@ -787,7 +784,7 @@ struct dentry *d_find_alias(struct inode *inode)
787 784
788 if (!hlist_empty(&inode->i_dentry)) { 785 if (!hlist_empty(&inode->i_dentry)) {
789 spin_lock(&inode->i_lock); 786 spin_lock(&inode->i_lock);
790 de = __d_find_alias(inode, 0); 787 de = __d_find_alias(inode);
791 spin_unlock(&inode->i_lock); 788 spin_unlock(&inode->i_lock);
792 } 789 }
793 return de; 790 return de;
@@ -2765,7 +2762,7 @@ struct dentry *d_materialise_unique(struct dentry *dentry, struct inode *inode)
2765 struct dentry *alias; 2762 struct dentry *alias;
2766 2763
2767 /* Does an aliased dentry already exist? */ 2764 /* Does an aliased dentry already exist? */
2768 alias = __d_find_alias(inode, 0); 2765 alias = __d_find_alias(inode);
2769 if (alias) { 2766 if (alias) {
2770 actual = alias; 2767 actual = alias;
2771 write_seqlock(&rename_lock); 2768 write_seqlock(&rename_lock);