From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757017AbYLJShd (ORCPT ); Wed, 10 Dec 2008 13:37:33 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752963AbYLJShV (ORCPT ); Wed, 10 Dec 2008 13:37:21 -0500 Received: from waste.org ([66.93.16.53]:57563 "EHLO waste.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750761AbYLJShT (ORCPT ); Wed, 10 Dec 2008 13:37:19 -0500 Subject: Re: [PATCH 04/15] kmemleak: Add the slob memory allocation/freeing hooks From: Matt Mackall To: Catalin Marinas Cc: linux-kernel@vger.kernel.org, Pekka Enberg In-Reply-To: <20081210182716.30323.13359.stgit@pc1117.cambridge.arm.com> References: <20081210182652.30323.4594.stgit@pc1117.cambridge.arm.com> <20081210182716.30323.13359.stgit@pc1117.cambridge.arm.com> Content-Type: text/plain Date: Wed, 10 Dec 2008 12:36:01 -0600 Message-Id: <1228934161.3726.124.camel@calx> Mime-Version: 1.0 X-Mailer: Evolution 2.22.3.1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 2008-12-10 at 18:27 +0000, Catalin Marinas wrote: > This patch adds the callbacks to memleak_(alloc|free) functions from the > slob allocator. Is this different than the last one? Acked-by: Matt Mackall > Signed-off-by: Catalin Marinas > Cc: Matt Mackall > Cc: Pekka Enberg > --- > mm/slob.c | 15 +++++++++++---- > 1 files changed, 11 insertions(+), 4 deletions(-) > > diff --git a/mm/slob.c b/mm/slob.c > index cb675d1..ff5a98d 100644 > --- a/mm/slob.c > +++ b/mm/slob.c > @@ -60,6 +60,7 @@ > #include > #include > #include > +#include > #include > #include > #include > @@ -463,6 +464,7 @@ void *__kmalloc_node(size_t size, gfp_t gfp, int node) > { > unsigned int *m; > int align = max(ARCH_KMALLOC_MINALIGN, ARCH_SLAB_MINALIGN); > + void *ret; > > if (size < PAGE_SIZE - align) { > if (!size) > @@ -472,18 +474,18 @@ void *__kmalloc_node(size_t size, gfp_t gfp, int node) > if (!m) > return NULL; > *m = size; > - return (void *)m + align; > + ret = (void *)m + align; > } else { > - void *ret; > - > ret = slob_new_page(gfp | __GFP_COMP, get_order(size), node); > if (ret) { > struct page *page; > page = virt_to_page(ret); > page->private = size; > } > - return ret; > } > + > + memleak_alloc(ret, size, 1, gfp); > + return ret; > } > EXPORT_SYMBOL(__kmalloc_node); > > @@ -493,6 +495,7 @@ void kfree(const void *block) > > if (unlikely(ZERO_OR_NULL_PTR(block))) > return; > + memleak_free(block); > > sp = (struct slob_page *)virt_to_page(block); > if (slob_page(sp)) { > @@ -555,12 +558,14 @@ struct kmem_cache *kmem_cache_create(const char *name, size_t size, > } else if (flags & SLAB_PANIC) > panic("Cannot create slab cache %s\n", name); > > + memleak_alloc(c, sizeof(struct kmem_cache), 1, GFP_KERNEL); > return c; > } > EXPORT_SYMBOL(kmem_cache_create); > > void kmem_cache_destroy(struct kmem_cache *c) > { > + memleak_free(c); > slob_free(c, sizeof(struct kmem_cache)); > } > EXPORT_SYMBOL(kmem_cache_destroy); > @@ -577,6 +582,7 @@ void *kmem_cache_alloc_node(struct kmem_cache *c, gfp_t flags, int node) > if (c->ctor) > c->ctor(b); > > + memleak_alloc_recursive(b, c->size, 1, c->flags, flags); > return b; > } > EXPORT_SYMBOL(kmem_cache_alloc_node); > @@ -599,6 +605,7 @@ static void kmem_rcu_free(struct rcu_head *head) > > void kmem_cache_free(struct kmem_cache *c, void *b) > { > + memleak_free_recursive(b, c->flags); > if (unlikely(c->flags & SLAB_DESTROY_BY_RCU)) { > struct slob_rcu *slob_rcu; > slob_rcu = b + (c->size - sizeof(struct slob_rcu)); -- Mathematics is the supreme nostalgia of our time.