aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc/omap/omap-hdmi.c
diff options
context:
space:
mode:
authorPeter Ujfalusi <peter.ujfalusi@ti.com>2012-09-14 08:05:57 -0400
committerMark Brown <broonie@opensource.wolfsonmicro.com>2012-09-22 11:13:02 -0400
commitbcd6da7bfd1bc3e9d5f8887967ec3d550ce56c70 (patch)
tree185bd9cd57ba3dbf3e223fe83e6bbd1a7ed8a92f /sound/soc/omap/omap-hdmi.c
parentf05cc9dac99ac6403d057d2cccb3c754714d2f32 (diff)
ASoC: OMAP: mcbsp, mcpdm, dmic, hdmi: Set dma_data at startup time
Set the dma_data for the stream (snd_soc_dai_set_dma_data) at dai_startup time so omap-pcm will have access to the needed information regarding to the DMA channel earlier. This is needed for the clean dmaengine support. Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com> Tested-by: Janusz Krzysztofik <jkrzyszt@tis.icnet.pl> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'sound/soc/omap/omap-hdmi.c')
-rw-r--r--sound/soc/omap/omap-hdmi.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/sound/soc/omap/omap-hdmi.c b/sound/soc/omap/omap-hdmi.c
index 095176738fd6..f59c69fb400e 100644
--- a/sound/soc/omap/omap-hdmi.c
+++ b/sound/soc/omap/omap-hdmi.c
@@ -67,6 +67,9 @@ static int omap_hdmi_dai_startup(struct snd_pcm_substream *substream,
67 dev_err(dai->dev, "audio not supported\n"); 67 dev_err(dai->dev, "audio not supported\n");
68 return -ENODEV; 68 return -ENODEV;
69 } 69 }
70
71 snd_soc_dai_set_dma_data(dai, substream, &priv->dma_params);
72
70 return 0; 73 return 0;
71} 74}
72 75
@@ -85,24 +88,24 @@ static int omap_hdmi_dai_hw_params(struct snd_pcm_substream *substream,
85 struct hdmi_priv *priv = snd_soc_dai_get_drvdata(dai); 88 struct hdmi_priv *priv = snd_soc_dai_get_drvdata(dai);
86 struct snd_aes_iec958 *iec = &priv->iec; 89 struct snd_aes_iec958 *iec = &priv->iec;
87 struct snd_cea_861_aud_if *cea = &priv->cea; 90 struct snd_cea_861_aud_if *cea = &priv->cea;
91 struct omap_pcm_dma_data *dma_data;
88 int err = 0; 92 int err = 0;
89 93
94 dma_data = snd_soc_dai_get_dma_data(dai, substream);
95
90 switch (params_format(params)) { 96 switch (params_format(params)) {
91 case SNDRV_PCM_FORMAT_S16_LE: 97 case SNDRV_PCM_FORMAT_S16_LE:
92 priv->dma_params.packet_size = 16; 98 dma_data->packet_size = 16;
93 break; 99 break;
94 case SNDRV_PCM_FORMAT_S24_LE: 100 case SNDRV_PCM_FORMAT_S24_LE:
95 priv->dma_params.packet_size = 32; 101 dma_data->packet_size = 32;
96 break; 102 break;
97 default: 103 default:
98 dev_err(dai->dev, "format not supported!\n"); 104 dev_err(dai->dev, "format not supported!\n");
99 return -EINVAL; 105 return -EINVAL;
100 } 106 }
101 107
102 priv->dma_params.data_type = 32; 108 dma_data->data_type = 32;
103
104 snd_soc_dai_set_dma_data(dai, substream,
105 &priv->dma_params);
106 109
107 /* 110 /*
108 * fill the IEC-60958 channel status word 111 * fill the IEC-60958 channel status word