提交 d93ca1ae 编写于 作者: G guoyh 提交者: Mark Brown

ASoC: pxa: allocate the SSP DMA parameters in startup

Allocating the SSP DMA parameters in startup, freeing it in
shutdown instead of freeing and re-allocating it in hw_params.
After doing that, the logic is clear and more safe.
Signed-off-by: Nguoyh <guoyh@marvell.com>
Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
上级 3cb81651
...@@ -85,14 +85,12 @@ struct pxa2xx_pcm_dma_data { ...@@ -85,14 +85,12 @@ struct pxa2xx_pcm_dma_data {
char name[20]; char name[20];
}; };
static struct pxa2xx_pcm_dma_params * static void pxa_ssp_set_dma_params(struct ssp_device *ssp, int width4,
pxa_ssp_get_dma_params(struct ssp_device *ssp, int width4, int out) int out, struct pxa2xx_pcm_dma_params *dma_data)
{ {
struct pxa2xx_pcm_dma_data *dma; struct pxa2xx_pcm_dma_data *dma;
dma = kzalloc(sizeof(struct pxa2xx_pcm_dma_data), GFP_KERNEL); dma = container_of(dma_data, struct pxa2xx_pcm_dma_data, params);
if (dma == NULL)
return NULL;
snprintf(dma->name, 20, "SSP%d PCM %s %s", ssp->port_id, snprintf(dma->name, 20, "SSP%d PCM %s %s", ssp->port_id,
width4 ? "32-bit" : "16-bit", out ? "out" : "in"); width4 ? "32-bit" : "16-bit", out ? "out" : "in");
...@@ -103,8 +101,6 @@ pxa_ssp_get_dma_params(struct ssp_device *ssp, int width4, int out) ...@@ -103,8 +101,6 @@ pxa_ssp_get_dma_params(struct ssp_device *ssp, int width4, int out)
(DCMD_INCTRGADDR | DCMD_FLOWSRC)) | (DCMD_INCTRGADDR | DCMD_FLOWSRC)) |
(width4 ? DCMD_WIDTH4 : DCMD_WIDTH2) | DCMD_BURST16; (width4 ? DCMD_WIDTH4 : DCMD_WIDTH2) | DCMD_BURST16;
dma->params.dev_addr = ssp->phys_base + SSDR; dma->params.dev_addr = ssp->phys_base + SSDR;
return &dma->params;
} }
static int pxa_ssp_startup(struct snd_pcm_substream *substream, static int pxa_ssp_startup(struct snd_pcm_substream *substream,
...@@ -112,6 +108,7 @@ static int pxa_ssp_startup(struct snd_pcm_substream *substream, ...@@ -112,6 +108,7 @@ static int pxa_ssp_startup(struct snd_pcm_substream *substream,
{ {
struct ssp_priv *priv = snd_soc_dai_get_drvdata(cpu_dai); struct ssp_priv *priv = snd_soc_dai_get_drvdata(cpu_dai);
struct ssp_device *ssp = priv->ssp; struct ssp_device *ssp = priv->ssp;
struct pxa2xx_pcm_dma_data *dma;
int ret = 0; int ret = 0;
if (!cpu_dai->active) { if (!cpu_dai->active) {
...@@ -119,8 +116,10 @@ static int pxa_ssp_startup(struct snd_pcm_substream *substream, ...@@ -119,8 +116,10 @@ static int pxa_ssp_startup(struct snd_pcm_substream *substream,
pxa_ssp_disable(ssp); pxa_ssp_disable(ssp);
} }
kfree(snd_soc_dai_get_dma_data(cpu_dai, substream)); dma = kzalloc(sizeof(struct pxa2xx_pcm_dma_data), GFP_KERNEL);
snd_soc_dai_set_dma_data(cpu_dai, substream, NULL); if (!dma)
return -ENOMEM;
snd_soc_dai_set_dma_data(cpu_dai, substream, &dma->params);
return ret; return ret;
} }
...@@ -573,18 +572,13 @@ static int pxa_ssp_hw_params(struct snd_pcm_substream *substream, ...@@ -573,18 +572,13 @@ static int pxa_ssp_hw_params(struct snd_pcm_substream *substream,
dma_data = snd_soc_dai_get_dma_data(cpu_dai, substream); dma_data = snd_soc_dai_get_dma_data(cpu_dai, substream);
/* generate correct DMA params */
kfree(dma_data);
/* Network mode with one active slot (ttsa == 1) can be used /* Network mode with one active slot (ttsa == 1) can be used
* to force 16-bit frame width on the wire (for S16_LE), even * to force 16-bit frame width on the wire (for S16_LE), even
* with two channels. Use 16-bit DMA transfers for this case. * with two channels. Use 16-bit DMA transfers for this case.
*/ */
dma_data = pxa_ssp_get_dma_params(ssp, pxa_ssp_set_dma_params(ssp,
((chn == 2) && (ttsa != 1)) || (width == 32), ((chn == 2) && (ttsa != 1)) || (width == 32),
substream->stream == SNDRV_PCM_STREAM_PLAYBACK); substream->stream == SNDRV_PCM_STREAM_PLAYBACK, dma_data);
snd_soc_dai_set_dma_data(cpu_dai, substream, dma_data);
/* we can only change the settings if the port is not in use */ /* we can only change the settings if the port is not in use */
if (pxa_ssp_read_reg(ssp, SSCR0) & SSCR0_SSE) if (pxa_ssp_read_reg(ssp, SSCR0) & SSCR0_SSE)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册