summaryrefslogtreecommitdiff
path: root/fs/befs/linuxvfs.c
diff options
context:
space:
mode:
authorStephen Rothwell <sfr@canb.auug.org.au>2010-12-31 10:55:42 +1100
committerStephen Rothwell <sfr@canb.auug.org.au>2010-12-31 10:55:42 +1100
commit46491588c6335cbc71ca660d9feb2c0d4f0f6401 (patch)
tree7f650ddd7b6e934c63332b75b0cd598006a714a9 /fs/befs/linuxvfs.c
parentd4a2c96152ed0290c0d6c7791f5315b2f01105ff (diff)
parent6245d166245845e40bd290b0df1ae99a2d5bbf63 (diff)
Merge remote branch 'vfs-scale/vfs-scale-working'
Conflicts: Documentation/filesystems/Locking fs/cifs/dir.c fs/fuse/inode.c fs/hfsplus/hfsplus_fs.h fs/hfsplus/unicode.c
Diffstat (limited to 'fs/befs/linuxvfs.c')
-rw-r--r--fs/befs/linuxvfs.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/fs/befs/linuxvfs.c b/fs/befs/linuxvfs.c
index aa4e7c7ae3c6..de93581b79a2 100644
--- a/fs/befs/linuxvfs.c
+++ b/fs/befs/linuxvfs.c
@@ -284,12 +284,18 @@ befs_alloc_inode(struct super_block *sb)
return &bi->vfs_inode;
}
-static void
-befs_destroy_inode(struct inode *inode)
+static void befs_i_callback(struct rcu_head *head)
{
+ struct inode *inode = container_of(head, struct inode, i_rcu);
+ INIT_LIST_HEAD(&inode->i_dentry);
kmem_cache_free(befs_inode_cachep, BEFS_I(inode));
}
+static void befs_destroy_inode(struct inode *inode)
+{
+ call_rcu(&inode->i_rcu, befs_i_callback);
+}
+
static void init_once(void *foo)
{
struct befs_inode_info *bi = (struct befs_inode_info *) foo;