mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-10-31 16:54:21 +00:00 
			
		
		
		
	 1d2c8eea69
			
		
	
	
		1d2c8eea69
		
	
	
	
	
		
			
			- rename ____kmalloc to kmalloc_track_caller so that people have a chance to guess what it does just from it's name. Add a comment describing it for those who don't. Also move it after kmalloc in slab.h so people get less confused when they are just looking for kmalloc - move things around in slab.c a little to reduce the ifdef mess. [penberg@cs.helsinki.fi: Fix up reversed #ifdef] Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Pekka Enberg <penberg@cs.helsinki.fi> Cc: Christoph Lameter <clameter@engr.sgi.com> Cc: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
		
			
				
	
	
		
			94 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include <linux/slab.h>
 | |
| #include <linux/string.h>
 | |
| #include <linux/module.h>
 | |
| #include <linux/err.h>
 | |
| #include <asm/uaccess.h>
 | |
| 
 | |
| /**
 | |
|  * __kzalloc - allocate memory. The memory is set to zero.
 | |
|  * @size: how many bytes of memory are required.
 | |
|  * @flags: the type of memory to allocate.
 | |
|  */
 | |
| void *__kzalloc(size_t size, gfp_t flags)
 | |
| {
 | |
| 	void *ret = kmalloc_track_caller(size, flags);
 | |
| 	if (ret)
 | |
| 		memset(ret, 0, size);
 | |
| 	return ret;
 | |
| }
 | |
| EXPORT_SYMBOL(__kzalloc);
 | |
| 
 | |
| /*
 | |
|  * kstrdup - allocate space for and copy an existing string
 | |
|  *
 | |
|  * @s: the string to duplicate
 | |
|  * @gfp: the GFP mask used in the kmalloc() call when allocating memory
 | |
|  */
 | |
| char *kstrdup(const char *s, gfp_t gfp)
 | |
| {
 | |
| 	size_t len;
 | |
| 	char *buf;
 | |
| 
 | |
| 	if (!s)
 | |
| 		return NULL;
 | |
| 
 | |
| 	len = strlen(s) + 1;
 | |
| 	buf = kmalloc_track_caller(len, gfp);
 | |
| 	if (buf)
 | |
| 		memcpy(buf, s, len);
 | |
| 	return buf;
 | |
| }
 | |
| EXPORT_SYMBOL(kstrdup);
 | |
| 
 | |
| /**
 | |
|  * kmemdup - duplicate region of memory
 | |
|  *
 | |
|  * @src: memory region to duplicate
 | |
|  * @len: memory region length
 | |
|  * @gfp: GFP mask to use
 | |
|  */
 | |
| void *kmemdup(const void *src, size_t len, gfp_t gfp)
 | |
| {
 | |
| 	void *p;
 | |
| 
 | |
| 	p = kmalloc_track_caller(len, gfp);
 | |
| 	if (p)
 | |
| 		memcpy(p, src, len);
 | |
| 	return p;
 | |
| }
 | |
| EXPORT_SYMBOL(kmemdup);
 | |
| 
 | |
| /*
 | |
|  * strndup_user - duplicate an existing string from user space
 | |
|  *
 | |
|  * @s: The string to duplicate
 | |
|  * @n: Maximum number of bytes to copy, including the trailing NUL.
 | |
|  */
 | |
| char *strndup_user(const char __user *s, long n)
 | |
| {
 | |
| 	char *p;
 | |
| 	long length;
 | |
| 
 | |
| 	length = strnlen_user(s, n);
 | |
| 
 | |
| 	if (!length)
 | |
| 		return ERR_PTR(-EFAULT);
 | |
| 
 | |
| 	if (length > n)
 | |
| 		return ERR_PTR(-EINVAL);
 | |
| 
 | |
| 	p = kmalloc(length, GFP_KERNEL);
 | |
| 
 | |
| 	if (!p)
 | |
| 		return ERR_PTR(-ENOMEM);
 | |
| 
 | |
| 	if (copy_from_user(p, s, length)) {
 | |
| 		kfree(p);
 | |
| 		return ERR_PTR(-EFAULT);
 | |
| 	}
 | |
| 
 | |
| 	p[length - 1] = '\0';
 | |
| 
 | |
| 	return p;
 | |
| }
 | |
| EXPORT_SYMBOL(strndup_user);
 |