Commit 8b5d9531 authored by Takashi Iwai's avatar Takashi Iwai Committed by Mark Brown

ASoC: amd: Fix reference to PCM buffer address

PCM buffers might be allocated dynamically when the buffer
preallocation failed or a larger buffer is requested, and it's not
guaranteed that substream->dma_buffer points to the actually used
buffer.  The driver needs to refer to substream->runtime->dma_addr
instead for the buffer address.

Cc: <stable@vger.kernel.org>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
Link: https://lore.kernel.org/r/20210731084331.32225-1-tiwai@suse.deSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 1d25684e
...@@ -969,7 +969,7 @@ static int acp_dma_hw_params(struct snd_soc_component *component, ...@@ -969,7 +969,7 @@ static int acp_dma_hw_params(struct snd_soc_component *component,
acp_set_sram_bank_state(rtd->acp_mmio, 0, true); acp_set_sram_bank_state(rtd->acp_mmio, 0, true);
/* Save for runtime private data */ /* Save for runtime private data */
rtd->dma_addr = substream->dma_buffer.addr; rtd->dma_addr = runtime->dma_addr;
rtd->order = get_order(size); rtd->order = get_order(size);
/* Fill the page table entries in ACP SRAM */ /* Fill the page table entries in ACP SRAM */
......
...@@ -286,7 +286,7 @@ static int acp3x_dma_hw_params(struct snd_soc_component *component, ...@@ -286,7 +286,7 @@ static int acp3x_dma_hw_params(struct snd_soc_component *component,
pr_err("pinfo failed\n"); pr_err("pinfo failed\n");
} }
size = params_buffer_bytes(params); size = params_buffer_bytes(params);
rtd->dma_addr = substream->dma_buffer.addr; rtd->dma_addr = substream->runtime->dma_addr;
rtd->num_pages = (PAGE_ALIGN(size) >> PAGE_SHIFT); rtd->num_pages = (PAGE_ALIGN(size) >> PAGE_SHIFT);
config_acp3x_dma(rtd, substream->stream); config_acp3x_dma(rtd, substream->stream);
return 0; return 0;
......
...@@ -242,7 +242,7 @@ static int acp_pdm_dma_hw_params(struct snd_soc_component *component, ...@@ -242,7 +242,7 @@ static int acp_pdm_dma_hw_params(struct snd_soc_component *component,
return -EINVAL; return -EINVAL;
size = params_buffer_bytes(params); size = params_buffer_bytes(params);
period_bytes = params_period_bytes(params); period_bytes = params_period_bytes(params);
rtd->dma_addr = substream->dma_buffer.addr; rtd->dma_addr = substream->runtime->dma_addr;
rtd->num_pages = (PAGE_ALIGN(size) >> PAGE_SHIFT); rtd->num_pages = (PAGE_ALIGN(size) >> PAGE_SHIFT);
config_acp_dma(rtd, substream->stream); config_acp_dma(rtd, substream->stream);
init_pdm_ring_buffer(MEM_WINDOW_START, size, period_bytes, init_pdm_ring_buffer(MEM_WINDOW_START, size, period_bytes,
......
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