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: Peter Ujfalusi <peter.ujfalusi@ti.com> Tested-by: Janusz Krzysztofik <jkrzyszt@tis.icnet.pl> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
This commit is contained in:
parent
04564e3258
commit
f05cc9dac9
3 changed files with 5 additions and 4 deletions
|
@ -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,
|
||||||
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)
|
||||||
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 {
|
||||||
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 */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue