nick kvfree() from apparmor
authorAl Viro <viro@zeniv.linux.org.uk>
Tue, 6 May 2014 18:02:53 +0000 (14:02 -0400)
committerGreg Hackmann <ghackmann@google.com>
Wed, 3 Sep 2014 19:56:24 +0000 (12:56 -0700)
too many places open-code it

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Conflicts:
mm/util.c
security/apparmor/include/apparmor.h

Change-Id: Ie8602e0199282dc462921cb7217158d1998853b0

include/linux/mm.h
mm/util.c
security/apparmor/include/apparmor.h
security/apparmor/lib.c

index 01eb01df92251a6d882e5c7c222d17cd57558901..ff7f6375f33ff26a236a4d5bd6b2c91fc5099156 100644 (file)
@@ -324,6 +324,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
index ab1424dbe2e6c9396ee66ab4446f1bc1cd557382..36aa4815e3dda0912ec5063b90eb7dd1d70529d7 100644 (file)
--- a/mm/util.c
+++ b/mm/util.c
@@ -7,6 +7,7 @@
 #include <linux/security.h>
 #include <linux/swap.h>
 #include <linux/swapops.h>
+#include <linux/vmalloc.h>
 #include <asm/uaccess.h>
 
 #include "internal.h"
@@ -384,6 +385,15 @@ unsigned long vm_mmap(struct file *file, unsigned long addr,
 }
 EXPORT_SYMBOL(vm_mmap);
 
+void kvfree(const void *addr)
+{
+       if (is_vmalloc_addr(addr))
+               vfree(addr);
+       else
+               kfree(addr);
+}
+EXPORT_SYMBOL(kvfree);
+
 struct address_space *page_mapping(struct page *page)
 {
        struct address_space *mapping = page->mapping;
index 40aedd9f73eaf76c7ccab0374d5ae48db3ee2a31..4a8cbfeef8b3ab41837beaad3ad3d34bc1487ad3 100644 (file)
@@ -65,7 +65,6 @@ extern int apparmor_initialized __initdata;
 char *aa_split_fqname(char *args, char **ns_name);
 void aa_info_message(const char *str);
 void *kvmalloc(size_t size);
-void kvfree(void *buffer);
 
 
 /**
index 5b62af7254ca072e61b8bac746c2c43b11de5561..ce8d9a84ab2d1f3f8906b72324e688536fef7b1b 100644 (file)
@@ -103,17 +103,3 @@ void *kvmalloc(size_t size)
        }
        return buffer;
 }
-
-/**
- * kvfree - free an allocation do by kvmalloc
- * @buffer: buffer to free (MAYBE_NULL)
- *
- * Free a buffer allocated by kvmalloc
- */
-void kvfree(void *buffer)
-{
-       if (is_vmalloc_addr(buffer))
-               vfree(buffer);
-       else
-               kfree(buffer);
-}