From 661aee9beee4c39f84614bc8cd5e66a614ead39d Mon Sep 17 00:00:00 2001 From: Al Viro Date: Sat, 23 Oct 2010 15:23:40 -0400 Subject: [PATCH] --- yaml --- r: 217794 b: refs/heads/master c: 756acc2d61712a8cafe2aa6ad626c60a185d3645 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/fs/hfsplus/inode.c | 2 +- trunk/fs/jfs/jfs_imap.c | 2 +- trunk/include/linux/list.h | 6 ++++++ 4 files changed, 9 insertions(+), 3 deletions(-) diff --git a/[refs] b/[refs] index fe026bbf2fe8..45b6056dbb9c 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 1d3382cbf02986e4833849f528d451367ea0b4cb +refs/heads/master: 756acc2d61712a8cafe2aa6ad626c60a185d3645 diff --git a/trunk/fs/hfsplus/inode.c b/trunk/fs/hfsplus/inode.c index 78449280dae0..8afd7e84f98d 100644 --- a/trunk/fs/hfsplus/inode.c +++ b/trunk/fs/hfsplus/inode.c @@ -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() * 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); out: diff --git a/trunk/fs/jfs/jfs_imap.c b/trunk/fs/jfs/jfs_imap.c index f8332dc8eeb2..3a09423b6c22 100644 --- a/trunk/fs/jfs/jfs_imap.c +++ b/trunk/fs/jfs/jfs_imap.c @@ -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() * will work fine and require no locking. */ - ip->i_hash.pprev = &ip->i_hash.next; + hlist_add_fake(&ip->i_hash); return (ip); } diff --git a/trunk/include/linux/list.h b/trunk/include/linux/list.h index 88a000617d77..9a5f8a71810c 100644 --- a/trunk/include/linux/list.h +++ b/trunk/include/linux/list.h @@ -636,6 +636,12 @@ static inline void hlist_add_after(struct hlist_node *n, 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 * reference of the first entry if it exists.