Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c67dc624 authored by Roman Penyaev's avatar Roman Penyaev Committed by Linus Torvalds
Browse files

mm/vmalloc: do not call kmemleak_free() on not yet accounted memory

__vmalloc_area_node() calls vfree() on error path, which in turn calls
kmemleak_free(), but area is not yet accounted by kmemleak_vmalloc().

Link: http://lkml.kernel.org/r/20190103145954.16942-3-rpenyaev@suse.de


Signed-off-by: default avatarRoman Penyaev <rpenyaev@suse.de>
Reviewed-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Cc: Michal Hocko <mhocko@suse.com>
Cc: Andrey Ryabinin <aryabinin@virtuozzo.com>
Cc: Joe Perches <joe@perches.com>
Cc: "Luis R. Rodriguez" <mcgrof@kernel.org>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 401592d2
Loading
Loading
Loading
Loading
+11 −5
Original line number Diff line number Diff line
@@ -1565,6 +1565,14 @@ void vfree_atomic(const void *addr)
	__vfree_deferred(addr);
}

static void __vfree(const void *addr)
{
	if (unlikely(in_interrupt()))
		__vfree_deferred(addr);
	else
		__vunmap(addr, 1);
}

/**
 *	vfree  -  release memory allocated by vmalloc()
 *	@addr:		memory base address
@@ -1591,10 +1599,8 @@ void vfree(const void *addr)

	if (!addr)
		return;
	if (unlikely(in_interrupt()))
		__vfree_deferred(addr);
	else
		__vunmap(addr, 1);

	__vfree(addr);
}
EXPORT_SYMBOL(vfree);

@@ -1709,7 +1715,7 @@ static void *__vmalloc_area_node(struct vm_struct *area, gfp_t gfp_mask,
	warn_alloc(gfp_mask, NULL,
			  "vmalloc: allocation failure, allocated %ld of %ld bytes",
			  (area->nr_pages*PAGE_SIZE), area->size);
	vfree(area->addr);
	__vfree(area->addr);
	return NULL;
}