[alsa-devel] [RESEND PATCH 1/1] ASoC: fsl_ssi: Fix checking of dai format for AC97 mode
arnaud.mouiche at invoxia.com
arnaud.mouiche at invoxia.com
Wed Sep 16 11:32:59 CEST 2015
Hello,
Please apply.
this kind of patch is here for a long time (I have posted one similar in
the past) and is a requirement to make DSP_A/B working on freescale.
regards,
arnaud
Le 16/09/2015 11:13, Adam Thomson a écrit :
> Current code incorrectly treats dai format for AC97 as bit mask
> whereas it's actually an integer value. This causes DAI formats
> other than AC97 (e.g. DSP_B) to trigger AC97 related code,
> which is incorrect and breaks functionality. This patch fixes
> the code to correctly compare values to determine AC97 or not.
>
> Signed-off-by: Adam Thomson <Adam.Thomson.Opensource at diasemi.com>
> ---
>
> Patch based on v4.3-rc1.
>
> sound/soc/fsl/fsl_ssi.c | 5 +++--
> 1 file changed, 3 insertions(+), 2 deletions(-)
>
> diff --git a/sound/soc/fsl/fsl_ssi.c b/sound/soc/fsl/fsl_ssi.c
> index 8ec6fb2..37c5cd4 100644
> --- a/sound/soc/fsl/fsl_ssi.c
> +++ b/sound/soc/fsl/fsl_ssi.c
> @@ -249,7 +249,8 @@ MODULE_DEVICE_TABLE(of, fsl_ssi_ids);
>
> static bool fsl_ssi_is_ac97(struct fsl_ssi_private *ssi_private)
> {
> - return !!(ssi_private->dai_fmt & SND_SOC_DAIFMT_AC97);
> + return (ssi_private->dai_fmt & SND_SOC_DAIFMT_FORMAT_MASK) ==
> + SND_SOC_DAIFMT_AC97;
> }
>
> static bool fsl_ssi_is_i2s_master(struct fsl_ssi_private *ssi_private)
> @@ -947,7 +948,7 @@ static int _fsl_ssi_set_dai_fmt(struct device *dev,
> CCSR_SSI_SCR_TCH_EN);
> }
>
> - if (fmt & SND_SOC_DAIFMT_AC97)
> + if ((fmt & SND_SOC_DAIFMT_FORMAT_MASK) == SND_SOC_DAIFMT_AC97)
> fsl_ssi_setup_ac97(ssi_private);
>
> return 0;
More information about the Alsa-devel
mailing list