diff options
author | Axel Lin <axel.lin@ingics.com> | 2015-07-19 10:42:49 -0400 |
---|---|---|
committer | Mark Brown <broonie@kernel.org> | 2015-07-20 13:16:16 -0400 |
commit | da304ac37efc1900892b5067c65f0ab8acfe3955 (patch) | |
tree | 743bd49ec65e1f2370f74c603b7b57c14cc6577a | |
parent | dedae86d4da6c88ec2105e0bd038acc57c203bca (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.c | 11 |
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 | ||