diff options
| author | Anton Vorontsov <avorontsov@mvista.com> | 2010-06-18 15:08:12 +0400 | 
|---|---|---|
| committer | Wolfgang Denk <wd@denx.de> | 2010-06-29 22:24:11 +0200 | 
| commit | 81f8d3b021ac9e567f06b44d7eb95f1a1409428d (patch) | |
| tree | 231b844bdc96ce45127fa3e7c299e88daaeaf885 | |
| parent | e365c43d6aa69b544a8f81d68596e89e9a3d6fa8 (diff) | |
| download | olio-uboot-2014.01-81f8d3b021ac9e567f06b44d7eb95f1a1409428d.tar.xz olio-uboot-2014.01-81f8d3b021ac9e567f06b44d7eb95f1a1409428d.zip | |
hwconfig: Fix stop characters parsing for subkeys
For the following hwconfig string:
  key1:subkey1=value1,subkey2=value2;key2:value3
The subkey2 cannot be extracted correctly. The parsing code looks
for comma as a stopch, but there may be two kind of stop characters:
a comma and a semicolon.
Currently the code would return "value2;key2:value3", while just
"value2" is the correct answer.
This patch fixes the issue by making the code aware of multiple
stop characters.
For old U-Boots, the issue can be workarounded by placing a comma
before a semicolon, i.e.:
  hwconfig=key1:subkey1=value1,subkey2=value2,;key2:value3
Reported-by: York Sun <yorksun@freescale.com>
Signed-off-by: Anton Vorontsov <avorontsov@mvista.com>
| -rw-r--r-- | common/hwconfig.c | 19 | 
1 files changed, 10 insertions, 9 deletions
| diff --git a/common/hwconfig.c b/common/hwconfig.c index e5c60ba7a..85a69da81 100644 --- a/common/hwconfig.c +++ b/common/hwconfig.c @@ -19,7 +19,7 @@  #include <linux/string.h>  static const char *hwconfig_parse(const char *opts, size_t maxlen, -				  const char *opt, char stopch, char eqch, +				  const char *opt, char *stopchs, char eqch,  				  size_t *arglen)  {  	size_t optlen = strlen(opt); @@ -33,8 +33,9 @@ next:  	if (end - start > maxlen)  		return NULL; -	if (str && (str == opts || str[-1] == stopch) && -			(*end == stopch || *end == eqch || *end == '\0')) { +	if (str && (str == opts || strpbrk(str - 1, stopchs) == str - 1) && +			(strpbrk(end, stopchs) == end || *end == eqch || +			 *end == '\0')) {  		const char *arg_end;  		if (!arglen) @@ -43,7 +44,7 @@ next:  		if (*end != eqch)  			return NULL; -		arg_end = strchr(str, stopch); +		arg_end = strpbrk(str, stopchs);  		if (!arg_end)  			*arglen = min(maxlen, strlen(str)) - optlen - 1;  		else @@ -66,15 +67,15 @@ static const char *__hwconfig(const char *opt, size_t *arglen)  	if (env_hwconfig)  		return hwconfig_parse(env_hwconfig, strlen(env_hwconfig), -				      opt, ';', ':', arglen); +				      opt, ";", ':', arglen);  	if (board_hwconfig)  		return hwconfig_parse(board_hwconfig, strlen(board_hwconfig), -				      opt, ';', ':', arglen); +				      opt, ";", ':', arglen);  	if (cpu_hwconfig)  		return hwconfig_parse(cpu_hwconfig, strlen(cpu_hwconfig), -				      opt, ';', ':', arglen); +				      opt, ";", ':', arglen);  	return NULL;  } @@ -164,7 +165,7 @@ int hwconfig_sub(const char *opt, const char *subopt)  	arg = __hwconfig(opt, &arglen);  	if (!arg)  		return 0; -	return !!hwconfig_parse(arg, arglen, subopt, ',', '=', NULL); +	return !!hwconfig_parse(arg, arglen, subopt, ",;", '=', NULL);  }  /* @@ -185,7 +186,7 @@ const char *hwconfig_subarg(const char *opt, const char *subopt,  	arg = __hwconfig(opt, &arglen);  	if (!arg)  		return NULL; -	return hwconfig_parse(arg, arglen, subopt, ',', '=', subarglen); +	return hwconfig_parse(arg, arglen, subopt, ",;", '=', subarglen);  }  /* |