Message ID | 1437316969.9569.1.camel@ingics.com (mailing list archive) |
---|---|
State | Accepted |
Commit | da304ac37efc1900892b5067c65f0ab8acfe3955 |
Headers | show |
On Sun, 19 Jul 2015, Axel Lin wrote: > Mode Control - Register 02h > > Digital Interface Format (DIF[2:0]) Bits 6-4 > > DIF2 DIF1 DIF0 Description > 0 0 0 Left-Justified, up to 24-bit data > 0 0 1 I²S, up to 24-bit data > 0 1 0 Right-Justified, 16-bit data > 0 1 1 Right-Justified, 24-bit data > 1 0 0 TDM slot 0 > 1 0 1 TDM slot 1 > 1 1 0 TDM slot 2 > 1 1 1 TDM slot 3 > > The DIF_MASK is 0x70, so current code does not correctly set the DIFx > setting. Fix it. > > Signed-off-by: Axel Lin <axel.lin@ingics.com> > --- > I assume the path "ASoC: cs4349: Don't use rtd->codec" will be applied > first, so this patch is on top of that patch. > > sound/soc/codecs/cs4349.c | 11 +++++------ > 1 file changed, 5 insertions(+), 6 deletions(-) > Good catch, thanks! Acked-by: Tim Howe <tim.howe@cirrus.com>
diff --git a/sound/soc/codecs/cs4349.c b/sound/soc/codecs/cs4349.c index 7f5c3c70..989289d 100644 --- a/sound/soc/codecs/cs4349.c +++ b/sound/soc/codecs/cs4349.c @@ -98,17 +98,16 @@ static int cs4349_pcm_hw_params(struct snd_pcm_substream *substream, { struct snd_soc_codec *codec = dai->codec; struct cs4349_private *cs4349 = snd_soc_codec_get_drvdata(codec); - int mode, fmt, ret; + int fmt, ret; - mode = snd_soc_read(codec, CS4349_MODE); cs4349->rate = params_rate(params); switch (cs4349->mode) { case SND_SOC_DAIFMT_I2S: - mode |= MODE_FORMAT(DIF_I2S); + fmt = DIF_I2S; break; case SND_SOC_DAIFMT_LEFT_J: - mode |= MODE_FORMAT(DIF_LEFT_JST); + fmt = DIF_LEFT_JST; break; case SND_SOC_DAIFMT_RIGHT_J: switch (params_width(params)) { @@ -121,13 +120,13 @@ static int cs4349_pcm_hw_params(struct snd_pcm_substream *substream, default: return -EINVAL; } - mode |= MODE_FORMAT(fmt); break; default: return -EINVAL; } - ret = snd_soc_write(codec, CS4349_MODE, mode); + ret = snd_soc_update_bits(codec, CS4349_MODE, DIF_MASK, + MODE_FORMAT(fmt)); if (ret < 0) return ret;
Mode Control - Register 02h Digital Interface Format (DIF[2:0]) Bits 6-4 DIF2 DIF1 DIF0 Description 0 0 0 Left-Justified, up to 24-bit data 0 0 1 I²S, up to 24-bit data 0 1 0 Right-Justified, 16-bit data 0 1 1 Right-Justified, 24-bit data 1 0 0 TDM slot 0 1 0 1 TDM slot 1 1 1 0 TDM slot 2 1 1 1 TDM slot 3 The DIF_MASK is 0x70, so current code does not correctly set the DIFx setting. Fix it. Signed-off-by: Axel Lin <axel.lin@ingics.com> --- I assume the path "ASoC: cs4349: Don't use rtd->codec" will be applied first, so this patch is on top of that patch. sound/soc/codecs/cs4349.c | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-)