diff mbox

ASoC: cs4349: Fix setting digital interface format

Message ID 1437316969.9569.1.camel@ingics.com (mailing list archive)
State Accepted
Commit da304ac37efc1900892b5067c65f0ab8acfe3955
Headers show

Commit Message

Axel Lin July 19, 2015, 2:42 p.m. UTC
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(-)

Comments

Howe, Tim July 30, 2015, 9:33 p.m. UTC | #1
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 mbox

Patch

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;