aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAxel Lin <axel.lin@ingics.com>2015-07-19 10:42:49 -0400
committerMark Brown <broonie@kernel.org>2015-07-20 13:16:16 -0400
commitda304ac37efc1900892b5067c65f0ab8acfe3955 (patch)
tree743bd49ec65e1f2370f74c603b7b57c14cc6577a
parentdedae86d4da6c88ec2105e0bd038acc57c203bca (diff)
ASoC: cs4349: Fix setting digital interface format
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> Signed-off-by: Mark Brown <broonie@kernel.org>
-rw-r--r--sound/soc/codecs/cs4349.c11
1 files changed, 5 insertions, 6 deletions
diff --git a/sound/soc/codecs/cs4349.c b/sound/soc/codecs/cs4349.c
index ab071675357e..4885695e35a7 100644
--- a/sound/soc/codecs/cs4349.c
+++ b/sound/soc/codecs/cs4349.c
@@ -96,17 +96,16 @@ static int cs4349_pcm_hw_params(struct snd_pcm_substream *substream,
96{ 96{
97 struct snd_soc_codec *codec = dai->codec; 97 struct snd_soc_codec *codec = dai->codec;
98 struct cs4349_private *cs4349 = snd_soc_codec_get_drvdata(codec); 98 struct cs4349_private *cs4349 = snd_soc_codec_get_drvdata(codec);
99 int mode, fmt, ret; 99 int fmt, ret;
100 100
101 mode = snd_soc_read(codec, CS4349_MODE);
102 cs4349->rate = params_rate(params); 101 cs4349->rate = params_rate(params);
103 102
104 switch (cs4349->mode) { 103 switch (cs4349->mode) {
105 case SND_SOC_DAIFMT_I2S: 104 case SND_SOC_DAIFMT_I2S:
106 mode |= MODE_FORMAT(DIF_I2S); 105 fmt = DIF_I2S;
107 break; 106 break;
108 case SND_SOC_DAIFMT_LEFT_J: 107 case SND_SOC_DAIFMT_LEFT_J:
109 mode |= MODE_FORMAT(DIF_LEFT_JST); 108 fmt = DIF_LEFT_JST;
110 break; 109 break;
111 case SND_SOC_DAIFMT_RIGHT_J: 110 case SND_SOC_DAIFMT_RIGHT_J:
112 switch (params_width(params)) { 111 switch (params_width(params)) {
@@ -119,13 +118,13 @@ static int cs4349_pcm_hw_params(struct snd_pcm_substream *substream,
119 default: 118 default:
120 return -EINVAL; 119 return -EINVAL;
121 } 120 }
122 mode |= MODE_FORMAT(fmt);
123 break; 121 break;
124 default: 122 default:
125 return -EINVAL; 123 return -EINVAL;
126 } 124 }
127 125
128 ret = snd_soc_write(codec, CS4349_MODE, mode); 126 ret = snd_soc_update_bits(codec, CS4349_MODE, DIF_MASK,
127 MODE_FORMAT(fmt));
129 if (ret < 0) 128 if (ret < 0)
130 return ret; 129 return ret;
131 130