[alsa-devel] [PATCH v2 07/13] topology: Add private data parser

Jin, Yao yao.jin at linux.intel.com
Wed Jul 8 15:31:27 CEST 2015



On 2015/7/8 16:57, Liam Girdwood wrote:
> On Tue, 2015-07-07 at 18:19 +0200, Takashi Iwai wrote:
>> On Tue, 07 Jul 2015 17:54:02 +0200,
>> Liam Girdwood wrote:
>>>
>>> On Wed, 2015-07-01 at 18:20 +0200, Takashi Iwai wrote:
>>>
>>>>
>>>>> +static int get_hex_num(const char *str)
>>>>> +{
>>>>> +	char *tmp, *s = NULL;
>>>>> +	int i = 0;
>>>>> +
>>>>> +	tmp = strdup(str);
>>>>> +	if (tmp == NULL)
>>>>> +		return -ENOMEM;
>>>>> +
>>>>> +	s = strtok(tmp, ",");
>>>>> +	while (s != NULL) {
>>>>> +		s = strtok(NULL, ",");
>>>>> +		i++;
>>>>> +	}
>>>>> +
>>>>> +	free(tmp);
>>>>> +	return i;
>>>>
>>>> Hmm, this just counts the number of comma + 1, so you don't need to
>>>> duplicate the string?
>>>>
>>>
>>> The string here is duplicated since strtok is destructive (it overwrites
>>> the delimiters with NULL) and the string is being used later on by the
>>> calling function.
>>
>> Yes, but what I meant is something like below:
>>
>> static int get_hex_num(const char *str)
>> {
>> 	int i = 0;
>>
>> 	if (!*str)
>> 		return 0;
>> 	for (;;) {
>> 		i++;
>> 		str = strchr(str, ',');
>> 		if (!str)
>> 			return i;
>> 		str++;
>> 	}
>> }
>>
>> ... so that it works without strdup().
>>
>> But it seems that strtok() skips the starting delimiter or handles
>> multiple delimiters as a single, so the result will become
>> inconsistent.  That is, all the following strings will give "a" and
>> "b" via strtok():
>> 	a,b
>> 	a,,b
>> 	,a,b
>> 	a,b,
>>
>> I guess you don't want to have an empty list element, right?
>>
> 
> Lets ask the author :) but IMO an empty list should be skipped here.
> 
> Yao, what's your rational behind this code ?

Sorry for replying late, I just see this mail.

The get_hex_num() returns the number of hexadecimal in string.

Say the string is "0x12,0x34,0x56,0x78" or "0x12,0x34,0x56,0x78,",
the get_hex_num() returns 4.

But if I use strchr, for above string, I get different number (3 or 4).
That's the reason I choose the strtok().

I do this is because I think user may append the comma at the end of
string.

> 
> Liam
> 


More information about the Alsa-devel mailing list