Commit f05cc9da authored by Peter Ujfalusi's avatar Peter Ujfalusi Committed by Mark Brown

ASoC: omap-pcm, omap-dmic: Change the use of omap_pcm_dma_data->data_type

Instead of the OMAP DMA data type definition the data_type will be used to
specify the number of bits the DMA word should be configured or 0 in case
when based on the stream's format the omap-pcm can decide the needed DMA
word size.
This feature is needed for the omap-hdmi where the sDMA need to be
configured for 32bit word type regardless of the audio format used.
Signed-off-by: default avatarPeter Ujfalusi <peter.ujfalusi@ti.com>
Tested-by: default avatarJanusz Krzysztofik <jkrzyszt@tis.icnet.pl>
Signed-off-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
parent 04564e32
...@@ -34,7 +34,6 @@ ...@@ -34,7 +34,6 @@
#include <sound/asoundef.h> #include <sound/asoundef.h>
#include <video/omapdss.h> #include <video/omapdss.h>
#include <plat/dma.h>
#include "omap-pcm.h" #include "omap-pcm.h"
#include "omap-hdmi.h" #include "omap-hdmi.h"
...@@ -100,7 +99,7 @@ static int omap_hdmi_dai_hw_params(struct snd_pcm_substream *substream, ...@@ -100,7 +99,7 @@ static int omap_hdmi_dai_hw_params(struct snd_pcm_substream *substream,
return -EINVAL; return -EINVAL;
} }
priv->dma_params.data_type = OMAP_DMA_DATA_TYPE_S32; priv->dma_params.data_type = 32;
snd_soc_dai_set_dma_data(dai, substream, snd_soc_dai_set_dma_data(dai, substream,
&priv->dma_params); &priv->dma_params);
......
...@@ -183,7 +183,8 @@ static int omap_pcm_prepare(struct snd_pcm_substream *substream) ...@@ -183,7 +183,8 @@ static int omap_pcm_prepare(struct snd_pcm_substream *substream)
memset(&dma_params, 0, sizeof(dma_params)); memset(&dma_params, 0, sizeof(dma_params));
if (dma_data->data_type) if (dma_data->data_type)
dma_params.data_type = dma_data->data_type; dma_params.data_type = omap_pcm_get_dma_type(
dma_data->data_type);
else else
dma_params.data_type = omap_pcm_get_dma_type( dma_params.data_type = omap_pcm_get_dma_type(
snd_pcm_format_physical_width(runtime->format)); snd_pcm_format_physical_width(runtime->format));
......
...@@ -32,7 +32,8 @@ struct omap_pcm_dma_data { ...@@ -32,7 +32,8 @@ struct omap_pcm_dma_data {
int dma_req; /* DMA request line */ int dma_req; /* DMA request line */
unsigned long port_addr; /* transmit/receive register */ unsigned long port_addr; /* transmit/receive register */
void (*set_threshold)(struct snd_pcm_substream *substream); void (*set_threshold)(struct snd_pcm_substream *substream);
int data_type; /* data type 8,16,32 */ int data_type; /* 8, 16, 32 (bits) or 0 to let omap-pcm
* to decide the sDMA data type */
int packet_size; /* packet size only in PACKET mode */ int packet_size; /* packet size only in PACKET mode */
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment