fs: move i_count increments into find_inode/find_inode_fast
Now that iunique is not abusing find_inode anymore we can move the i_ref increment back to where it belongs. Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
ad5e195ac9
commit
f7899bd547
17
fs/inode.c
17
fs/inode.c
@ -634,9 +634,6 @@ static struct shrinker icache_shrinker = {
|
|||||||
static void __wait_on_freeing_inode(struct inode *inode);
|
static void __wait_on_freeing_inode(struct inode *inode);
|
||||||
/*
|
/*
|
||||||
* Called with the inode lock held.
|
* Called with the inode lock held.
|
||||||
* NOTE: we are not increasing the inode-refcount, you must call __iget()
|
|
||||||
* by hand after calling find_inode now! This simplifies iunique and won't
|
|
||||||
* add any additional branch in the common code.
|
|
||||||
*/
|
*/
|
||||||
static struct inode *find_inode(struct super_block *sb,
|
static struct inode *find_inode(struct super_block *sb,
|
||||||
struct hlist_head *head,
|
struct hlist_head *head,
|
||||||
@ -656,9 +653,10 @@ repeat:
|
|||||||
__wait_on_freeing_inode(inode);
|
__wait_on_freeing_inode(inode);
|
||||||
goto repeat;
|
goto repeat;
|
||||||
}
|
}
|
||||||
break;
|
__iget(inode);
|
||||||
|
return inode;
|
||||||
}
|
}
|
||||||
return node ? inode : NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -681,9 +679,10 @@ repeat:
|
|||||||
__wait_on_freeing_inode(inode);
|
__wait_on_freeing_inode(inode);
|
||||||
goto repeat;
|
goto repeat;
|
||||||
}
|
}
|
||||||
break;
|
__iget(inode);
|
||||||
|
return inode;
|
||||||
}
|
}
|
||||||
return node ? inode : NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
@ -828,7 +827,6 @@ static struct inode *get_new_inode(struct super_block *sb,
|
|||||||
* us. Use the old inode instead of the one we just
|
* us. Use the old inode instead of the one we just
|
||||||
* allocated.
|
* allocated.
|
||||||
*/
|
*/
|
||||||
__iget(old);
|
|
||||||
spin_unlock(&inode_lock);
|
spin_unlock(&inode_lock);
|
||||||
destroy_inode(inode);
|
destroy_inode(inode);
|
||||||
inode = old;
|
inode = old;
|
||||||
@ -875,7 +873,6 @@ static struct inode *get_new_inode_fast(struct super_block *sb,
|
|||||||
* us. Use the old inode instead of the one we just
|
* us. Use the old inode instead of the one we just
|
||||||
* allocated.
|
* allocated.
|
||||||
*/
|
*/
|
||||||
__iget(old);
|
|
||||||
spin_unlock(&inode_lock);
|
spin_unlock(&inode_lock);
|
||||||
destroy_inode(inode);
|
destroy_inode(inode);
|
||||||
inode = old;
|
inode = old;
|
||||||
@ -989,7 +986,6 @@ static struct inode *ifind(struct super_block *sb,
|
|||||||
spin_lock(&inode_lock);
|
spin_lock(&inode_lock);
|
||||||
inode = find_inode(sb, head, test, data);
|
inode = find_inode(sb, head, test, data);
|
||||||
if (inode) {
|
if (inode) {
|
||||||
__iget(inode);
|
|
||||||
spin_unlock(&inode_lock);
|
spin_unlock(&inode_lock);
|
||||||
if (likely(wait))
|
if (likely(wait))
|
||||||
wait_on_inode(inode);
|
wait_on_inode(inode);
|
||||||
@ -1022,7 +1018,6 @@ static struct inode *ifind_fast(struct super_block *sb,
|
|||||||
spin_lock(&inode_lock);
|
spin_lock(&inode_lock);
|
||||||
inode = find_inode_fast(sb, head, ino);
|
inode = find_inode_fast(sb, head, ino);
|
||||||
if (inode) {
|
if (inode) {
|
||||||
__iget(inode);
|
|
||||||
spin_unlock(&inode_lock);
|
spin_unlock(&inode_lock);
|
||||||
wait_on_inode(inode);
|
wait_on_inode(inode);
|
||||||
return inode;
|
return inode;
|
||||||
|
Loading…
Reference in New Issue
Block a user