mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-31 00:01:35 +00:00 
			
		
		
		
	 e108526e77
			
		
	
	
		e108526e77
		
	
	
	
	
		
			
			James Bottomley warns that inclusion of linux/fs.h in a low level driver was always a danger signal. This patch moves memory_read_from_buffer() from fs.h to string.h and fixes includes in existing memory_read_from_buffer() users. Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com> Cc: James Bottomley <James.Bottomley@hansenpartnership.com> Cc: Geert Uytterhoeven <geert@linux-m68k.org> Cc: Zhang Rui <rui.zhang@intel.com> Cc: Bob Moore <robert.moore@intel.com> Cc: Thomas Renninger <trenn@suse.de> Cc: Len Brown <lenb@kernel.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			119 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _LINUX_STRING_H_
 | |
| #define _LINUX_STRING_H_
 | |
| 
 | |
| /* We don't want strings.h stuff being user by user stuff by accident */
 | |
| 
 | |
| #ifndef __KERNEL__
 | |
| #include <string.h>
 | |
| #else
 | |
| 
 | |
| #include <linux/compiler.h>	/* for inline */
 | |
| #include <linux/types.h>	/* for size_t */
 | |
| #include <linux/stddef.h>	/* for NULL */
 | |
| 
 | |
| extern char *strndup_user(const char __user *, long);
 | |
| 
 | |
| /*
 | |
|  * Include machine specific inline routines
 | |
|  */
 | |
| #include <asm/string.h>
 | |
| 
 | |
| #ifndef __HAVE_ARCH_STRCPY
 | |
| extern char * strcpy(char *,const char *);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRNCPY
 | |
| extern char * strncpy(char *,const char *, __kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRLCPY
 | |
| size_t strlcpy(char *, const char *, size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRCAT
 | |
| extern char * strcat(char *, const char *);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRNCAT
 | |
| extern char * strncat(char *, const char *, __kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRLCAT
 | |
| extern size_t strlcat(char *, const char *, __kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRCMP
 | |
| extern int strcmp(const char *,const char *);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRNCMP
 | |
| extern int strncmp(const char *,const char *,__kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRNICMP
 | |
| extern int strnicmp(const char *, const char *, __kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRCASECMP
 | |
| extern int strcasecmp(const char *s1, const char *s2);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRNCASECMP
 | |
| extern int strncasecmp(const char *s1, const char *s2, size_t n);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRCHR
 | |
| extern char * strchr(const char *,int);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRNCHR
 | |
| extern char * strnchr(const char *, size_t, int);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRRCHR
 | |
| extern char * strrchr(const char *,int);
 | |
| #endif
 | |
| extern char * strstrip(char *);
 | |
| #ifndef __HAVE_ARCH_STRSTR
 | |
| extern char * strstr(const char *,const char *);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRLEN
 | |
| extern __kernel_size_t strlen(const char *);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRNLEN
 | |
| extern __kernel_size_t strnlen(const char *,__kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRPBRK
 | |
| extern char * strpbrk(const char *,const char *);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRSEP
 | |
| extern char * strsep(char **,const char *);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRSPN
 | |
| extern __kernel_size_t strspn(const char *,const char *);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_STRCSPN
 | |
| extern __kernel_size_t strcspn(const char *,const char *);
 | |
| #endif
 | |
| 
 | |
| #ifndef __HAVE_ARCH_MEMSET
 | |
| extern void * memset(void *,int,__kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_MEMCPY
 | |
| extern void * memcpy(void *,const void *,__kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_MEMMOVE
 | |
| extern void * memmove(void *,const void *,__kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_MEMSCAN
 | |
| extern void * memscan(void *,int,__kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_MEMCMP
 | |
| extern int memcmp(const void *,const void *,__kernel_size_t);
 | |
| #endif
 | |
| #ifndef __HAVE_ARCH_MEMCHR
 | |
| extern void * memchr(const void *,int,__kernel_size_t);
 | |
| #endif
 | |
| 
 | |
| extern char *kstrdup(const char *s, gfp_t gfp);
 | |
| extern char *kstrndup(const char *s, size_t len, gfp_t gfp);
 | |
| extern void *kmemdup(const void *src, size_t len, gfp_t gfp);
 | |
| 
 | |
| extern char **argv_split(gfp_t gfp, const char *str, int *argcp);
 | |
| extern void argv_free(char **argv);
 | |
| 
 | |
| extern bool sysfs_streq(const char *s1, const char *s2);
 | |
| 
 | |
| extern ssize_t memory_read_from_buffer(void *to, size_t count, loff_t *ppos,
 | |
| 			const void *from, size_t available);
 | |
| 
 | |
| #endif
 | |
| #endif /* _LINUX_STRING_H_ */
 |