git.openpandora.org
/
pandora-kernel.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4
[pandora-kernel.git]
/
fs
/
ext4
/
super.c
diff --git
a/fs/ext4/super.c
b/fs/ext4/super.c
index
757cb24
..
29c80f6
100644
(file)
--- a/
fs/ext4/super.c
+++ b/
fs/ext4/super.c
@@
-845,6
+845,13
@@
static int ext4_drop_inode(struct inode *inode)
return drop;
}
return drop;
}
+static void ext4_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(ext4_inode_cachep, EXT4_I(inode));
+}
+
static void ext4_destroy_inode(struct inode *inode)
{
ext4_ioend_wait(inode);
static void ext4_destroy_inode(struct inode *inode)
{
ext4_ioend_wait(inode);
@@
-857,7
+864,7
@@
static void ext4_destroy_inode(struct inode *inode)
true);
dump_stack();
}
true);
dump_stack();
}
-
kmem_cache_free(ext4_inode_cachep, EXT4_I(inode)
);
+
call_rcu(&inode->i_rcu, ext4_i_callback
);
}
static void init_once(void *foo)
}
static void init_once(void *foo)