For files only using THIS_MODULE and/or EXPORT_SYMBOL, map them onto including export.h -- or if the file isn't even using those, then just delete the include. Fix up any implicit include dependencies that were being masked by module.h along the way. Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
		
			
				
	
	
		
			101 lines
		
	
	
	
		
			1.8 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
	
		
			1.8 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * Helper function for splitting a string into an argv-like array.
 | 
						|
 */
 | 
						|
 | 
						|
#include <linux/kernel.h>
 | 
						|
#include <linux/ctype.h>
 | 
						|
#include <linux/string.h>
 | 
						|
#include <linux/slab.h>
 | 
						|
#include <linux/export.h>
 | 
						|
 | 
						|
static const char *skip_arg(const char *cp)
 | 
						|
{
 | 
						|
	while (*cp && !isspace(*cp))
 | 
						|
		cp++;
 | 
						|
 | 
						|
	return cp;
 | 
						|
}
 | 
						|
 | 
						|
static int count_argc(const char *str)
 | 
						|
{
 | 
						|
	int count = 0;
 | 
						|
 | 
						|
	while (*str) {
 | 
						|
		str = skip_spaces(str);
 | 
						|
		if (*str) {
 | 
						|
			count++;
 | 
						|
			str = skip_arg(str);
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	return count;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * argv_free - free an argv
 | 
						|
 * @argv - the argument vector to be freed
 | 
						|
 *
 | 
						|
 * Frees an argv and the strings it points to.
 | 
						|
 */
 | 
						|
void argv_free(char **argv)
 | 
						|
{
 | 
						|
	char **p;
 | 
						|
	for (p = argv; *p; p++)
 | 
						|
		kfree(*p);
 | 
						|
 | 
						|
	kfree(argv);
 | 
						|
}
 | 
						|
EXPORT_SYMBOL(argv_free);
 | 
						|
 | 
						|
/**
 | 
						|
 * argv_split - split a string at whitespace, returning an argv
 | 
						|
 * @gfp: the GFP mask used to allocate memory
 | 
						|
 * @str: the string to be split
 | 
						|
 * @argcp: returned argument count
 | 
						|
 *
 | 
						|
 * Returns an array of pointers to strings which are split out from
 | 
						|
 * @str.  This is performed by strictly splitting on white-space; no
 | 
						|
 * quote processing is performed.  Multiple whitespace characters are
 | 
						|
 * considered to be a single argument separator.  The returned array
 | 
						|
 * is always NULL-terminated.  Returns NULL on memory allocation
 | 
						|
 * failure.
 | 
						|
 */
 | 
						|
char **argv_split(gfp_t gfp, const char *str, int *argcp)
 | 
						|
{
 | 
						|
	int argc = count_argc(str);
 | 
						|
	char **argv = kzalloc(sizeof(*argv) * (argc+1), gfp);
 | 
						|
	char **argvp;
 | 
						|
 | 
						|
	if (argv == NULL)
 | 
						|
		goto out;
 | 
						|
 | 
						|
	if (argcp)
 | 
						|
		*argcp = argc;
 | 
						|
 | 
						|
	argvp = argv;
 | 
						|
 | 
						|
	while (*str) {
 | 
						|
		str = skip_spaces(str);
 | 
						|
 | 
						|
		if (*str) {
 | 
						|
			const char *p = str;
 | 
						|
			char *t;
 | 
						|
 | 
						|
			str = skip_arg(str);
 | 
						|
 | 
						|
			t = kstrndup(p, str-p, gfp);
 | 
						|
			if (t == NULL)
 | 
						|
				goto fail;
 | 
						|
			*argvp++ = t;
 | 
						|
		}
 | 
						|
	}
 | 
						|
	*argvp = NULL;
 | 
						|
 | 
						|
  out:
 | 
						|
	return argv;
 | 
						|
 | 
						|
  fail:
 | 
						|
	argv_free(argv);
 | 
						|
	return NULL;
 | 
						|
}
 | 
						|
EXPORT_SYMBOL(argv_split);
 |