Commit fb6a2a8e authored by Al Viro's avatar Al Viro Committed by Jiri Slaby

nick kvfree() from apparmor

commit 39f1f78d upstream.

too many places open-code it
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
Signed-off-by: default avatarJiri Slaby <jslaby@suse.cz>
parent 75f208f5
...@@ -334,6 +334,8 @@ static inline int is_vmalloc_or_module_addr(const void *x) ...@@ -334,6 +334,8 @@ static inline int is_vmalloc_or_module_addr(const void *x)
} }
#endif #endif
extern void kvfree(const void *addr);
static inline void compound_lock(struct page *page) static inline void compound_lock(struct page *page)
{ {
#ifdef CONFIG_TRANSPARENT_HUGEPAGE #ifdef CONFIG_TRANSPARENT_HUGEPAGE
......
...@@ -7,6 +7,7 @@ ...@@ -7,6 +7,7 @@
#include <linux/security.h> #include <linux/security.h>
#include <linux/swap.h> #include <linux/swap.h>
#include <linux/swapops.h> #include <linux/swapops.h>
#include <linux/vmalloc.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#include "internal.h" #include "internal.h"
...@@ -380,6 +381,15 @@ unsigned long vm_mmap(struct file *file, unsigned long addr, ...@@ -380,6 +381,15 @@ unsigned long vm_mmap(struct file *file, unsigned long addr,
} }
EXPORT_SYMBOL(vm_mmap); 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 *page_mapping(struct page *page)
{ {
struct address_space *mapping = page->mapping; struct address_space *mapping = page->mapping;
......
...@@ -66,7 +66,6 @@ extern int apparmor_initialized __initdata; ...@@ -66,7 +66,6 @@ extern int apparmor_initialized __initdata;
char *aa_split_fqname(char *args, char **ns_name); char *aa_split_fqname(char *args, char **ns_name);
void aa_info_message(const char *str); void aa_info_message(const char *str);
void *__aa_kvmalloc(size_t size, gfp_t flags); void *__aa_kvmalloc(size_t size, gfp_t flags);
void kvfree(void *buffer);
static inline void *kvmalloc(size_t size) static inline void *kvmalloc(size_t size)
{ {
......
...@@ -104,17 +104,3 @@ void *__aa_kvmalloc(size_t size, gfp_t flags) ...@@ -104,17 +104,3 @@ void *__aa_kvmalloc(size_t size, gfp_t flags)
} }
return buffer; 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);
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment