[alsa-devel] [PATCH v3 04/11] ALSA: core: Expand DMA buffer information
Vinod Koul
vkoul at kernel.org
Tue Jan 28 11:59:46 CET 2020
On 28-01-20, 11:43, Cezary Rojewski wrote:
> Update DMA buffer definition for snd_compr_runtime so it is represented
> similarly as in snd_pcm_runtime. While at it, modify
> snd_compr_set_runtime_buffer to account for newly added members.
Please run ./scripts/get_maintainer.pl, it will tell you the people you
should CC on a patch.
Also Takashi already acked, so you should add the acks/reviews received
in subsequent versions (unless they changed)
And for this:
Acked-by: Vinod Koul <vkoul at kernel.org>
> Signed-off-by: Cezary Rojewski <cezary.rojewski at intel.com>
> ---
> include/sound/compress_driver.h | 35 ++++++++++++++++++++++++---------
> 1 file changed, 26 insertions(+), 9 deletions(-)
>
> diff --git a/include/sound/compress_driver.h b/include/sound/compress_driver.h
> index bc88d6f964da..00f633c0c3ba 100644
> --- a/include/sound/compress_driver.h
> +++ b/include/sound/compress_driver.h
> @@ -23,7 +23,6 @@ struct snd_compr_ops;
> * struct snd_compr_runtime: runtime stream description
> * @state: stream state
> * @ops: pointer to DSP callbacks
> - * @dma_buffer_p: runtime dma buffer pointer
> * @buffer: pointer to kernel buffer, valid only when not in mmap mode or
> * DSP doesn't implement copy
> * @buffer_size: size of the above buffer
> @@ -34,11 +33,14 @@ struct snd_compr_ops;
> * @total_bytes_transferred: cumulative bytes transferred by offload DSP
> * @sleep: poll sleep
> * @private_data: driver private data pointer
> + * @dma_area: virtual buffer address
> + * @dma_addr: physical buffer address (not accessible from main CPU)
> + * @dma_bytes: size of DMA area
> + * @dma_buffer_p: runtime dma buffer pointer
> */
> struct snd_compr_runtime {
> snd_pcm_state_t state;
> struct snd_compr_ops *ops;
> - struct snd_dma_buffer *dma_buffer_p;
> void *buffer;
> u64 buffer_size;
> u32 fragment_size;
> @@ -47,6 +49,11 @@ struct snd_compr_runtime {
> u64 total_bytes_transferred;
> wait_queue_head_t sleep;
> void *private_data;
> +
> + unsigned char *dma_area;
> + dma_addr_t dma_addr;
> + size_t dma_bytes;
> + struct snd_dma_buffer *dma_buffer_p;
> };
>
> /**
> @@ -180,19 +187,29 @@ static inline void snd_compr_drain_notify(struct snd_compr_stream *stream)
>
> /**
> * snd_compr_set_runtime_buffer - Set the Compress runtime buffer
> - * @substream: compress substream to set
> + * @stream: compress stream to set
> * @bufp: the buffer information, NULL to clear
> *
> * Copy the buffer information to runtime buffer when @bufp is non-NULL.
> * Otherwise it clears the current buffer information.
> */
> -static inline void snd_compr_set_runtime_buffer(
> - struct snd_compr_stream *substream,
> - struct snd_dma_buffer *bufp)
> +static inline void
> +snd_compr_set_runtime_buffer(struct snd_compr_stream *stream,
> + struct snd_dma_buffer *bufp)
> {
> - struct snd_compr_runtime *runtime = substream->runtime;
> -
> - runtime->dma_buffer_p = bufp;
> + struct snd_compr_runtime *runtime = stream->runtime;
> +
> + if (bufp) {
> + runtime->dma_buffer_p = bufp;
> + runtime->dma_area = bufp->area;
> + runtime->dma_addr = bufp->addr;
> + runtime->dma_bytes = bufp->bytes;
> + } else {
> + runtime->dma_buffer_p = NULL;
> + runtime->dma_area = NULL;
> + runtime->dma_addr = 0;
> + runtime->dma_bytes = 0;
> + }
> }
>
> int snd_compr_stop_error(struct snd_compr_stream *stream,
> --
> 2.17.1
>
> _______________________________________________
> Alsa-devel mailing list
> Alsa-devel at alsa-project.org
> https://mailman.alsa-project.org/mailman/listinfo/alsa-devel
--
~Vinod
More information about the Alsa-devel
mailing list