ASoC: tlv320dac33: BCLK divider fix
authorPeter Ujfalusi <peter.ujfalusi@nokia.com>
Wed, 20 Jan 2010 07:39:35 +0000 (09:39 +0200)
committerMark Brown <broonie@opensource.wolfsonmicro.com>
Wed, 20 Jan 2010 11:47:49 +0000 (11:47 +0000)
The BCLK divider was not configured in case of mode7.
This leads to unpredictable behavior when switching between FIFO modes.
Configure the BCLK divider depending on the fifo_mode (FIFO is in use,
or FIFO bypass).

Signed-off-by: Peter Ujfalusi <peter.ujfalusi@nokia.com>
Acked-by: Liam Girdwood <lrg@slimlogic.co.uk>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
sound/soc/codecs/tlv320dac33.c

index 65683aa3920ce736ac3600e509290e2c03cfb9ce..e1aa66ff7f1c2fe8d97fc8ea37a95cafdaa90404 100644 (file)
@@ -845,11 +845,14 @@ static int dac33_prepare_chip(struct snd_pcm_substream *substream)
        dac33_write(codec, DAC33_SER_AUDIOIF_CTRL_A, aictrl_a);
        dac33_write(codec, DAC33_SER_AUDIOIF_CTRL_B, aictrl_b);
 
-       switch (dac33->fifo_mode) {
-       case DAC33_FIFO_MODE1:
-               /* 20: BCLK divide ratio */
+       /* BCLK divide ratio */
+       if (dac33->fifo_mode)
                dac33_write(codec, DAC33_SER_AUDIOIF_CTRL_C, 3);
+       else
+               dac33_write(codec, DAC33_SER_AUDIOIF_CTRL_C, 32);
 
+       switch (dac33->fifo_mode) {
+       case DAC33_FIFO_MODE1:
                dac33_write16(codec, DAC33_ATHR_MSB,
                              DAC33_THRREG(dac33->alarm_threshold));
                break;
@@ -864,8 +867,6 @@ static int dac33_prepare_chip(struct snd_pcm_substream *substream)
                        DAC33_THRREG(10));
                break;
        default:
-               /* BYPASS mode */
-               dac33_write(codec, DAC33_SER_AUDIOIF_CTRL_C, 32);
                break;
        }