Re: [PATCH] kmemleak: Only use GFP_KERNEL|GFP_ATOMIC for the internal allocations
From: Pekka Enberg
Date: Wed Jun 17 2009 - 09:01:43 EST
Hi Catalin,
On Wed, Jun 17, 2009 at 3:52 PM, Catalin Marinas<catalin.marinas@xxxxxxx> wrote:
> Kmemleak allocates memory for pointer tracking and it tries to avoid
> using GFP_ATOMIC if the caller doesn't require it. However other gfp
> flags may be passed by the caller which aren't required by kmemleak.
> This patch filters the gfp flags so that only GFP_KERNEL | GFP_ATOMIC
> are used.
>
> Signed-off-by: Catalin Marinas <catalin.marinas@xxxxxxx>
Is this really safe? What if we're in a middle of a filesystem
operation that uses GFP_NOFAIL and all of a sudden kmemleak allocation
fails and causes a panic?
Pekka
> ---
> mm/kmemleak.c | 7 +++++--
> 1 files changed, 5 insertions(+), 2 deletions(-)
>
> diff --git a/mm/kmemleak.c b/mm/kmemleak.c
> index 58ec86c..25e2034 100644
> --- a/mm/kmemleak.c
> +++ b/mm/kmemleak.c
> @@ -109,6 +109,9 @@
>
> #define BYTES_PER_POINTER sizeof(void *)
>
> +/* GFP bitmask for kmemleak internal allocations */
> +#define GFP_KMEMLEAK_MASK (GFP_KERNEL | GFP_ATOMIC)
> +
> /* scanning area inside a memory block */
> struct kmemleak_scan_area {
> struct hlist_node node;
> @@ -462,7 +465,7 @@ static void create_object(unsigned long ptr, size_t size, int min_count,
> struct prio_tree_node *node;
> struct stack_trace trace;
>
> - object = kmem_cache_alloc(object_cache, gfp & ~GFP_SLAB_BUG_MASK);
> + object = kmem_cache_alloc(object_cache, gfp & GFP_KMEMLEAK_MASK);
> if (!object) {
> kmemleak_panic("kmemleak: Cannot allocate a kmemleak_object "
> "structure\n");
> @@ -636,7 +639,7 @@ static void add_scan_area(unsigned long ptr, unsigned long offset,
> return;
> }
>
> - area = kmem_cache_alloc(scan_area_cache, gfp & ~GFP_SLAB_BUG_MASK);
> + area = kmem_cache_alloc(scan_area_cache, gfp & GFP_KMEMLEAK_MASK);
> if (!area) {
> kmemleak_warn("kmemleak: Cannot allocate a scan area\n");
> goto out;
>
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at http://www.tux.org/lkml/
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/