aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc/codecs
diff options
context:
space:
mode:
authorPeter Ujfalusi <peter.ujfalusi@nokia.com>2010-12-22 03:45:17 -0500
committerLiam Girdwood <lrg@slimlogic.co.uk>2010-12-23 09:38:33 -0500
commit549675ed658761b9a84cb579795c9ec1da227fea (patch)
treee654797f639078ca02b9cd3ebf2501642a08c4cb /sound/soc/codecs
parent3591f4cd53a3835e6d59dd509337503c2c61173e (diff)
ASoC: tlv320dac33: Some cleanup for 32/24 bit support
Change the structure of FIFO handling in order to pave the way for adding 32/24 bit audio support. Signed-off-by: Peter Ujfalusi <peter.ujfalusi@nokia.com> Acked-by: Mark Brown <broonie@opensource.wolfsonmicro.com> Signed-off-by: Liam Girdwood <lrg@slimlogic.co.uk>
Diffstat (limited to 'sound/soc/codecs')
-rw-r--r--sound/soc/codecs/tlv320dac33.c47
1 files changed, 27 insertions, 20 deletions
diff --git a/sound/soc/codecs/tlv320dac33.c b/sound/soc/codecs/tlv320dac33.c
index c574ae238973..05a4e9fade47 100644
--- a/sound/soc/codecs/tlv320dac33.c
+++ b/sound/soc/codecs/tlv320dac33.c
@@ -42,12 +42,15 @@
42#include <sound/tlv320dac33-plat.h> 42#include <sound/tlv320dac33-plat.h>
43#include "tlv320dac33.h" 43#include "tlv320dac33.h"
44 44
45#define DAC33_BUFFER_SIZE_BYTES 24576 /* bytes, 12288 16 bit words, 45/*
46 * 6144 stereo */ 46 * The internal FIFO is 24576 bytes long
47#define DAC33_BUFFER_SIZE_SAMPLES 6144 47 * It can be configured to hold 16bit or 24bit samples
48 48 * In 16bit configuration the FIFO can hold 6144 stereo samples
49#define MODE7_LTHR 10 49 * In 24bit configuration the FIFO can hold 4096 stereo samples
50#define MODE7_UTHR (DAC33_BUFFER_SIZE_SAMPLES - 10) 50 */
51#define DAC33_FIFO_SIZE_16BIT 6144
52#define DAC33_FIFO_SIZE_24BIT 4096
53#define DAC33_MODE7_MARGIN 10 /* Safety margin for FIFO in Mode7 */
51 54
52#define BURST_BASEFREQ_HZ 49152000 55#define BURST_BASEFREQ_HZ 49152000
53 56
@@ -98,6 +101,7 @@ struct tlv320dac33_priv {
98 101
99 unsigned int alarm_threshold; /* set to be half of LATENCY_TIME_MS */ 102 unsigned int alarm_threshold; /* set to be half of LATENCY_TIME_MS */
100 enum dac33_fifo_modes fifo_mode;/* FIFO mode selection */ 103 enum dac33_fifo_modes fifo_mode;/* FIFO mode selection */
104 unsigned int fifo_size; /* Size of the FIFO in samples */
101 unsigned int nsample; /* burst read amount from host */ 105 unsigned int nsample; /* burst read amount from host */
102 int mode1_latency; /* latency caused by the i2c writes in 106 int mode1_latency; /* latency caused by the i2c writes in
103 * us */ 107 * us */
@@ -650,7 +654,7 @@ static inline void dac33_prefill_handler(struct tlv320dac33_priv *dac33)
650 spin_unlock_irq(&dac33->lock); 654 spin_unlock_irq(&dac33->lock);
651 655
652 dac33_write16(codec, DAC33_PREFILL_MSB, 656 dac33_write16(codec, DAC33_PREFILL_MSB,
653 DAC33_THRREG(MODE7_LTHR)); 657 DAC33_THRREG(DAC33_MODE7_MARGIN));
654 658
655 /* Enable Upper Threshold IRQ */ 659 /* Enable Upper Threshold IRQ */
656 dac33_write(codec, DAC33_FIFO_IRQ_MASK, DAC33_MUT); 660 dac33_write(codec, DAC33_FIFO_IRQ_MASK, DAC33_MUT);
@@ -773,12 +777,15 @@ static void dac33_shutdown(struct snd_pcm_substream *substream,
773 dac33->substream = NULL; 777 dac33->substream = NULL;
774} 778}
775 779
780#define CALC_BURST_RATE(bclkdiv, bclk_per_sample) \
781 (BURST_BASEFREQ_HZ / bclkdiv / bclk_per_sample)
776static int dac33_hw_params(struct snd_pcm_substream *substream, 782static int dac33_hw_params(struct snd_pcm_substream *substream,
777 struct snd_pcm_hw_params *params, 783 struct snd_pcm_hw_params *params,
778 struct snd_soc_dai *dai) 784 struct snd_soc_dai *dai)
779{ 785{
780 struct snd_soc_pcm_runtime *rtd = substream->private_data; 786 struct snd_soc_pcm_runtime *rtd = substream->private_data;
781 struct snd_soc_codec *codec = rtd->codec; 787 struct snd_soc_codec *codec = rtd->codec;
788 struct tlv320dac33_priv *dac33 = snd_soc_codec_get_drvdata(codec);
782 789
783 /* Check parameters for validity */ 790 /* Check parameters for validity */
784 switch (params_rate(params)) { 791 switch (params_rate(params)) {
@@ -793,6 +800,8 @@ static int dac33_hw_params(struct snd_pcm_substream *substream,
793 800
794 switch (params_format(params)) { 801 switch (params_format(params)) {
795 case SNDRV_PCM_FORMAT_S16_LE: 802 case SNDRV_PCM_FORMAT_S16_LE:
803 dac33->fifo_size = DAC33_FIFO_SIZE_16BIT;
804 dac33->burst_rate = CALC_BURST_RATE(dac33->burst_bclkdiv, 32);
796 break; 805 break;
797 default: 806 default:
798 dev_err(codec->dev, "unsupported format %d\n", 807 dev_err(codec->dev, "unsupported format %d\n",
@@ -994,7 +1003,8 @@ static int dac33_prepare_chip(struct snd_pcm_substream *substream)
994 * at the bottom, and also at the top of the FIFO 1003 * at the bottom, and also at the top of the FIFO
995 */ 1004 */
996 dac33_write16(codec, DAC33_UTHR_MSB, DAC33_THRREG(dac33->uthr)); 1005 dac33_write16(codec, DAC33_UTHR_MSB, DAC33_THRREG(dac33->uthr));
997 dac33_write16(codec, DAC33_LTHR_MSB, DAC33_THRREG(MODE7_LTHR)); 1006 dac33_write16(codec, DAC33_LTHR_MSB,
1007 DAC33_THRREG(DAC33_MODE7_MARGIN));
998 break; 1008 break;
999 default: 1009 default:
1000 break; 1010 break;
@@ -1023,8 +1033,7 @@ static void dac33_calculate_times(struct snd_pcm_substream *substream)
1023 /* Number of samples under i2c latency */ 1033 /* Number of samples under i2c latency */
1024 dac33->alarm_threshold = US_TO_SAMPLES(rate, 1034 dac33->alarm_threshold = US_TO_SAMPLES(rate,
1025 dac33->mode1_latency); 1035 dac33->mode1_latency);
1026 nsample_limit = DAC33_BUFFER_SIZE_SAMPLES - 1036 nsample_limit = dac33->fifo_size - dac33->alarm_threshold;
1027 dac33->alarm_threshold;
1028 1037
1029 if (period_size <= dac33->alarm_threshold) 1038 if (period_size <= dac33->alarm_threshold)
1030 /* 1039 /*
@@ -1048,14 +1057,14 @@ static void dac33_calculate_times(struct snd_pcm_substream *substream)
1048 case DAC33_FIFO_MODE7: 1057 case DAC33_FIFO_MODE7:
1049 dac33->uthr = UTHR_FROM_PERIOD_SIZE(period_size, rate, 1058 dac33->uthr = UTHR_FROM_PERIOD_SIZE(period_size, rate,
1050 dac33->burst_rate) + 9; 1059 dac33->burst_rate) + 9;
1051 if (dac33->uthr > MODE7_UTHR) 1060 if (dac33->uthr > (dac33->fifo_size - DAC33_MODE7_MARGIN))
1052 dac33->uthr = MODE7_UTHR; 1061 dac33->uthr = dac33->fifo_size - DAC33_MODE7_MARGIN;
1053 if (dac33->uthr < (MODE7_LTHR + 10)) 1062 if (dac33->uthr < (DAC33_MODE7_MARGIN + 10))
1054 dac33->uthr = (MODE7_LTHR + 10); 1063 dac33->uthr = (DAC33_MODE7_MARGIN + 10);
1055 1064
1056 dac33->mode7_us_to_lthr = 1065 dac33->mode7_us_to_lthr =
1057 SAMPLES_TO_US(substream->runtime->rate, 1066 SAMPLES_TO_US(substream->runtime->rate,
1058 dac33->uthr - MODE7_LTHR + 1); 1067 dac33->uthr - DAC33_MODE7_MARGIN + 1);
1059 dac33->t_stamp1 = 0; 1068 dac33->t_stamp1 = 0;
1060 break; 1069 break;
1061 default: 1070 default:
@@ -1173,8 +1182,8 @@ static snd_pcm_sframes_t dac33_dai_delay(
1173 samples += (samples_in - samples_out); 1182 samples += (samples_in - samples_out);
1174 1183
1175 if (likely(samples > 0)) 1184 if (likely(samples > 0))
1176 delay = samples > DAC33_BUFFER_SIZE_SAMPLES ? 1185 delay = samples > dac33->fifo_size ?
1177 DAC33_BUFFER_SIZE_SAMPLES : samples; 1186 dac33->fifo_size : samples;
1178 else 1187 else
1179 delay = 0; 1188 delay = 0;
1180 } 1189 }
@@ -1226,7 +1235,7 @@ static snd_pcm_sframes_t dac33_dai_delay(
1226 samples_in = US_TO_SAMPLES( 1235 samples_in = US_TO_SAMPLES(
1227 dac33->burst_rate, 1236 dac33->burst_rate,
1228 time_delta); 1237 time_delta);
1229 delay = MODE7_LTHR + samples_in - samples_out; 1238 delay = DAC33_MODE7_MARGIN + samples_in - samples_out;
1230 1239
1231 if (unlikely(delay > uthr)) 1240 if (unlikely(delay > uthr))
1232 delay = uthr; 1241 delay = uthr;
@@ -1477,8 +1486,6 @@ static int __devinit dac33_i2c_probe(struct i2c_client *client,
1477 1486
1478 dac33->power_gpio = pdata->power_gpio; 1487 dac33->power_gpio = pdata->power_gpio;
1479 dac33->burst_bclkdiv = pdata->burst_bclkdiv; 1488 dac33->burst_bclkdiv = pdata->burst_bclkdiv;
1480 /* Pre calculate the burst rate */
1481 dac33->burst_rate = BURST_BASEFREQ_HZ / dac33->burst_bclkdiv / 32;
1482 dac33->keep_bclk = pdata->keep_bclk; 1489 dac33->keep_bclk = pdata->keep_bclk;
1483 dac33->mode1_latency = pdata->mode1_latency; 1490 dac33->mode1_latency = pdata->mode1_latency;
1484 if (!dac33->mode1_latency) 1491 if (!dac33->mode1_latency)