[alsa-devel] [PATCH 1/2] ASoC: codecs: ad193x: Fix memory corruption on BE 64b systems

gianluca gianlucarenzi at eurek.it
Wed Jun 26 14:45:11 CEST 2019


On 06/26/2019 12:49 PM, Codrin Ciubotariu wrote:
> Since change_bit() requires unsigned long*, making this cast on an
> unsigned int variable will change a wrong bit on BE platforms, causing
> memory corruption. Replace this function with a simple XOR.
>
> Fixes: 90f6e6803139 ("ASoC: codecs: ad193x: Fix frame polarity for DSP_A format")
> Reported-by: Dan Carpenter <dan.carpenter at oracle.com>
> Signed-off-by: Codrin Ciubotariu <codrin.ciubotariu at microchip.com>
> ---
>  sound/soc/codecs/ad193x.c | 6 ++----
>  1 file changed, 2 insertions(+), 4 deletions(-)
>
> diff --git a/sound/soc/codecs/ad193x.c b/sound/soc/codecs/ad193x.c
> index 05f4514048e2..3ebc0524f4b2 100644
> --- a/sound/soc/codecs/ad193x.c
> +++ b/sound/soc/codecs/ad193x.c
> @@ -240,10 +240,8 @@ static int ad193x_set_dai_fmt(struct snd_soc_dai *codec_dai,
>  	}
>
>  	/* For DSP_*, LRCLK's polarity must be inverted */
> -	if (fmt & SND_SOC_DAIFMT_DSP_A) {
> -		change_bit(ffs(AD193X_DAC_LEFT_HIGH) - 1,
> -			   (unsigned long *)&dac_fmt);
> -	}
> +	if (fmt & SND_SOC_DAIFMT_DSP_A)
> +		dac_fmt ^= AD193X_DAC_LEFT_HIGH;
>

BigEndian RULEZ! ;-P


-- 
Eurek s.r.l.                          |
Electronic Engineering                | http://www.eurek.it
via Celletta 8/B, 40026 Imola, Italy  | Phone: +39-(0)542-609120
p.iva 00690621206 - c.f. 04020030377  | Fax:   +39-(0)542-609212


More information about the Alsa-devel mailing list