Sorry, you'll need this patch too. Ben. -- Ben Hutchings Make three consecutive correct guesses and you will be considered an expert.
From: Al Viro <viro@zeniv.linux.org.uk> Date: Tue, 6 May 2014 14:02:53 -0400 Subject: nick kvfree() from apparmor Origin: https://git.kernel.org/linus/39f1f78d53b9bcbca91967380c5f0f2305a5c55f too many places open-code it Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> [bwh: Backported to 3.2: kvfree() was not in AppArmor, so just add it] --- include/linux/mm.h | 2 ++ mm/util.c | 10 ++++++++++ security/apparmor/include/apparmor.h | 1 - security/apparmor/lib.c | 14 -------------- 4 files changed, 12 insertions(+), 15 deletions(-) diff --git a/include/linux/mm.h b/include/linux/mm.h index bf9811e1321a..d6777060449f 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h @@ -317,6 +317,8 @@ static inline int is_vmalloc_or_module_addr(const void *x) } #endif +extern void kvfree(const void *addr); + static inline void compound_lock(struct page *page) { #ifdef CONFIG_TRANSPARENT_HUGEPAGE diff --git a/mm/util.c b/mm/util.c index f380af7ea779..d5ea733c5082 100644 --- a/mm/util.c +++ b/mm/util.c @@ -4,6 +4,7 @@ #include <linux/export.h> #include <linux/err.h> #include <linux/sched.h> +#include <linux/vmalloc.h> #include <asm/uaccess.h> #include "internal.h" @@ -307,3 +308,12 @@ unsigned long vm_mmap(struct file *file, unsigned long addr, EXPORT_TRACEPOINT_SYMBOL(kmem_cache_alloc_node); EXPORT_TRACEPOINT_SYMBOL(kfree); EXPORT_TRACEPOINT_SYMBOL(kmem_cache_free); + +void kvfree(const void *addr) +{ + if (is_vmalloc_addr(addr)) + vfree(addr); + else + kfree(addr); +} +EXPORT_SYMBOL(kvfree);
Attachment:
signature.asc
Description: This is a digitally signed message part