Commit 756acc2d authored by Al Viro's avatar Al Viro

list.h: new helper - hlist_add_fake()

Make node look as if it was on hlist, with hlist_del()
working correctly.  Usable without any locking...

Convert a couple of places where we want to do that to
inode->i_hash.
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 1d3382cb
...@@ -211,7 +211,7 @@ static struct dentry *hfsplus_file_lookup(struct inode *dir, struct dentry *dent ...@@ -211,7 +211,7 @@ static struct dentry *hfsplus_file_lookup(struct inode *dir, struct dentry *dent
* appear hashed, but do not put on any lists. hlist_del() * appear hashed, but do not put on any lists. hlist_del()
* will work fine and require no locking. * will work fine and require no locking.
*/ */
inode->i_hash.pprev = &inode->i_hash.next; hlist_add_fake(&inode->i_hash);
mark_inode_dirty(inode); mark_inode_dirty(inode);
out: out:
......
...@@ -497,7 +497,7 @@ struct inode *diReadSpecial(struct super_block *sb, ino_t inum, int secondary) ...@@ -497,7 +497,7 @@ struct inode *diReadSpecial(struct super_block *sb, ino_t inum, int secondary)
* appear hashed, but do not put on any lists. hlist_del() * appear hashed, but do not put on any lists. hlist_del()
* will work fine and require no locking. * will work fine and require no locking.
*/ */
ip->i_hash.pprev = &ip->i_hash.next; hlist_add_fake(&ip->i_hash);
return (ip); return (ip);
} }
......
...@@ -636,6 +636,12 @@ static inline void hlist_add_after(struct hlist_node *n, ...@@ -636,6 +636,12 @@ static inline void hlist_add_after(struct hlist_node *n,
next->next->pprev = &next->next; next->next->pprev = &next->next;
} }
/* after that we'll appear to be on some hlist and hlist_del will work */
static inline void hlist_add_fake(struct hlist_node *n)
{
n->pprev = &n->next;
}
/* /*
* Move a list from one list head to another. Fixup the pprev * Move a list from one list head to another. Fixup the pprev
* reference of the first entry if it exists. * reference of the first entry if it exists.
......
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