[alsa-devel] Question about snd_soc_8_8_write

Kuninori Morimoto morimoto.kuninori at renesas.com
Mon Dec 14 05:30:06 CET 2009


Dear Mark

I have question about snd_soc_8_8_write

-----------------------------
static int snd_soc_8_8_write(struct snd_soc_codec *codec, unsigned int reg,
			     unsigned int value)
{
	u8 *cache = codec->reg_cache;
	u8 data[2];

	BUG_ON(codec->volatile_register);

	data[0] = reg & 0xff;
	data[1] = value & 0xff;

	if (reg < codec->reg_cache_size)
		cache[reg] = value;

	if (codec->hw_write(codec->control_data, data, 2) == 2)
		return 0;
	else
		return -EIO;
}
-----------------------------

I wounder this behavior.

if reg >= codec->reg_cache_size,
this functions will call hw_write
though cache[xx] ignore it.

And 
even though if reg < codec->reg_cache_size,
if hw_write return error, cache[xx] value was still changed.

This is correct behavior ?
Or are there any reason ?

Best regards
--
Kuninori Morimoto
 


More information about the Alsa-devel mailing list