From: Minfei Huang Date: Thu, 22 May 2014 00:43:39 +0000 (+1000) Subject: lib/btree.c: fix leak of whole btree nodes X-Git-Tag: next-20140530~2^2~164 X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=52f60bae3c3d5b63da96715308be4daff43e49b9;p=karo-tx-linux.git lib/btree.c: fix leak of whole btree nodes I use btree from 3.14-rc2 in my own module. When the btree module is removed, a warning arises: kmem_cache_destroy btree_node: Slab cache still has objects CPU: 13 PID: 9150 Comm: rmmod Tainted: GF O 3.14.0-rc2 #1 Hardware name: Inspur NF5270M3/NF5270M3, BIOS CHEETAH_2.1.3 09/10/2013 ffff881ff8643b18 ffff881ffdc23ea8 ffffffff815a4ecc 0000000000000000 ffff881ff8643ac0 ffff881ffdc23ec8 ffffffff811610df 0000000000000880 ffffffffa057da60 ffff881ffdc23ed8 ffffffffa057d57c ffff881ffdc23f78 Call Trace: [] dump_stack+0x49/0x5d [] kmem_cache_destroy+0xcf/0xe0 [] btree_module_exit+0x10/0x12 [btree] [] SyS_delete_module+0x198/0x1f0 [] ? retint_swapgs+0xe/0x13 [] ? trace_hardirqs_on_caller+0xfd/0x1c0 [] ? trace_hardirqs_on_thunk+0x3a/0x3f [] system_call_fastpath+0x16/0x1b The cause is that it doesn't release the last btree node, when height = 1 and fill = 1. Signed-off-by: Minfei Huang Cc: Joern Engel Cc: Johannes Berg Signed-off-by: Andrew Morton --- diff --git a/lib/btree.c b/lib/btree.c index f9a484676cb6..725bf8b4f6c2 100644 --- a/lib/btree.c +++ b/lib/btree.c @@ -198,6 +198,8 @@ EXPORT_SYMBOL_GPL(btree_init); void btree_destroy(struct btree_head *head) { + if (head->node) + mempool_free(head->node, head->mempool); mempool_destroy(head->mempool); head->mempool = NULL; }