[alsa-devel] [PATCH] ASoC: dapm - Add API calls to query valid DAPM paths.
Liam Girdwood
lrg at ti.com
Thu Jul 7 20:20:10 CEST 2011
On 07/07/11 17:38, Mark Brown wrote:
> On Thu, Jul 07, 2011 at 05:18:47PM +0100, Liam Girdwood wrote:
>
>> The reason for using a separate walk here was because this code is
>> taken from my old auto-router and it was to avoid the extra logic
>> introduced by the auto-router. The auto-router did need to check for
>> loops and always select the shortest path when > 1 path was viable
>> (interesting as WM9713 has both loops and multiple paths). Let me see
>> how cleanly I can merge it into the current walk.
>
> Alternatively could we replace the current walk? It's O(n^2) or so in
> the number of widgets so it's not the greatest treasure ever. So long
> as we only have one walk and it works I'm happy.
>
>>> It does also occur to me that perhaps what we want to do here is allow
>>> widgets to find out about paths when they're being activated anyway?
>
>> For dynamic PCM, we need to also work out which DAIs are active based
>> on the graph. Hence for playback we can supply the DAC/AIF and find
>> out all the connected output AIF/Speakers/Pins/etc. This is required
>> at the start of open() in order that we can call the other PCM ops for
>> each DAI, codec and platform.
>
> Right, that's not really what I'm saying though - I'm saying that
> widgets in general could be interested in this information. For
> example, some charge pumps can save additional power with some input
> signal paths (which is currently handled but this would make that code
> more general).
Ok, but I'm not stopping this sort of functionality from being added
later. Right now this is not a priority (for me anyway).
>
>>>> + * snd_soc_dapm_get_connected_widgets_type - query audio path and it's widgets.
>>>> + * @dapm: the dapm context.
>>>> + * @stream_name: stream name.
>>>> + * @list: list of active widgets for this stream.
>>>> + * @stream: stream direction.
>>>> + * @type: Initial widget type.
>>>> + *
>>>> + * Queries DAPM graph as to whether an valid audio stream path exists for
>>>> + * the DAPM stream and initial widget type specified. This takes into account
>>>> + * current mixer and mux kcontrol settings. Creates list of valid widgets.
>>>
>>> Why would someone want to query by type? That seems surprising. Name
>>> and/or direction yes but type seems hard to find a use for.
>
>> We query by type so that we can qualify the root widget for a shared
>> common stream name. i.e. Dynamic DSP needs to find the AIF rather than
>> a DAC for stream X.
>
> It does? Hrm. Perhaps it would make life simpler if we just mandated
> the use of explicit AIF widgets?
But we may also want to know what was after a DAC. I'm thinking back
from the conference discussions where we could use this information to
selectively enable/disable kcontrols. However, this is not going to be
used at the moment either so I'll stick by the AIF widgets.
Liam
More information about the Alsa-devel
mailing list