2021-05-21 20:19:01

by Takashi Iwai

[permalink] [raw]
Subject: Re: [RFC PATCH 0/6] soc-pcm: Add separate snd_pcm_runtime for BEs

On Thu, 20 May 2021 15:59:02 +0200,
<[email protected]> wrote:
>
> On 19.05.2021 18:41, Takashi Iwai wrote:
> > On Wed, 19 May 2021 17:08:10 +0200,
> > <[email protected]> wrote:
> >>
> >> On 19.05.2021 17:15, Takashi Iwai wrote:
> >>> EXTERNAL EMAIL: Do not click links or open attachments unless you know the content is safe
> >>>
> >>> On Wed, 19 May 2021 12:48:36 +0200,
> >>> Codrin Ciubotariu wrote:
> >>>>
> >>>> This patchset adds a different snd_pcm_runtime in the BE's substream,
> >>>> replacing the FE's snd_pcm_runtime. With a different structure, the BE
> >>>> HW capabilities and constraints will no longer merge with the FE ones.
> >>>> This allows for error detection if the be_hw_params_fixup() applies HW
> >>>> parameters not supported by the BE DAIs. Also, it calculates values
> >>>> needed for mem-to-dev/dev-to-mem DMA transfers, such as buffer size and
> >>>> period size, if needed.
> >>>>
> >>>> The first 4 patches are preparatory patches, that just group and export
> >>>> functions used to allocate and initialize the snd_pcm_runtime. Also, the
> >>>> functions that set and apply the HW constraints are exported.
> >>>> The 5th patch does (almost) everything need to create the new snd_pcm_runtime
> >>>> for BEs, which includes allocation, initializing the HW capabilities,
> >>>> HW constraints and HW parameters. The BE HW parameters are no longer
> >>>> copied from the FE. They are recalculated, based on HW capabilities,
> >>>> constraints and the be_hw_params_fixup() callback.
> >>>> The 6th and last patch basically adds support for the PCM generic
> >>>> dmaengine to be used as a platform driver for BE DAI links. It allocates
> >>>> a buffer, needed by the DMA transfers that do not support dev-to-dev
> >>>> transfers between FE and BE DAIs.
> >>>>
> >>>> This is a superset of
> >>>> https://mailman.alsa-project.org/pipermail/alsa-devel/2021-March/182630.html
> >>>> which only handles the BE HW constraints. This patchset aims to be more
> >>>> complete, defining a a snd_pcm_runtime between each FE and BE and can
> >>>> be used between any DAI link connection. I am sure I am not handling all
> >>>> the needed members of snd_pcm_runtime (such as handling
> >>>> struct snd_pcm_mmap_status *status), but I would like to have your
> >>>> feedback regarding this idea.
> >>>
> >>> I'm also concerned about the handling of other fields in runtime
> >>> object, maybe allocating a complete runtime object for each BE is an
> >>> overkill and fragile. Could it be rather only hw_constraints to be
> >>> unique for each BE, instead?
> >>
> >> I tried with only the hw constraints in the previous patchset and it's
> >> difficult to handle the snd_pcm_hw_rule_add() calls, without changing
> >> the function's declaration. This solution requires no changes to
> >> constraints API, nor to their 'clients'. I agree that handling all the
> >> runtime fields might be over-complicated. From what I see, the scary
> >> ones are used to describe the buffer and the status of the transfers. I
> >> do not think there are BEs that use these values at this moment (the FE
> >> ones). I think that the HW params, private section, hardware description
> >> and maybe DMA members (at least in my case) are mostly needed by BEs.
> >
> > OK, I'll check your previous series again, but my gut feeling is for
> > pursuit to the hw_constraints hacks. e.g. we may split
> > snd_pcm_hw_constraints and snd_pcm_hw_rule, too, if that matters.
>
> Something like adding snd_pcm_hw_rule directly under
> snd_pcm_runtime, to store the BE constraints? It could work, but I think
> we should also be able to remove rules, if one BE gets disconnected.
> This means that we will need a way to identify or separate them, for
> each BE, right?

Well, if each BE needs a different set of hw constraint rules, it
needs its own unique copies instead of sharing the rules. Is it your
requirement?


Takashi