[alsa-devel] [PATCH] ASoC: dapm: Add speaker driver widget.

Mark Brown broonie at opensource.wolfsonmicro.com
Tue Dec 7 15:13:39 CET 2010


On Tue, Dec 07, 2010 at 02:01:24PM +0000, Liam Girdwood wrote:
> On Tue, 2010-12-07 at 13:09 +0000, Mark Brown wrote:

> > You can say that for pretty much all of the widgets, though, including
> > the existing speaker and headphone widgets.  

> You can only really say for the last widget in the sequence.

Pretty much anything might be the last widget in the chain, and
obviously you can need to do stuff like this within the CODEC as well as
the machine (after all that's exactly what this is about).

For full flexibility we need something like optional sorting within each
widget type.

> @@ -61,6 +61,7 @@ static int dapm_up_seq[] = {
>         [snd_soc_dapm_mixer] = 7,
>         [snd_soc_dapm_mixer_named_ctl] = 7,
>         [snd_soc_dapm_pga] = 8,
> +       [snd_soc_dapm_drv] = 9,
>         [snd_soc_dapm_adc] = 9,
>         [snd_soc_dapm_hp] = 10,
>         [snd_soc_dapm_spk] = 10,

> This patch shares the ADC sequence number for the DRV on the power ON.

This isn't entirely great for digital bypass paths (the current setup
isn't ideal either but that's a separate issue and harder to fix as you
can get PGAs on both input and output paths).  You'll power up your
output driver and only then start feeding through samples from the ADC,
meaning a sudden introduction of any DC offset in the analogue input
that the ADC is passing through rather than getting the benefit of any
soft start or DC offset correction the hardware does.  I'd rather see us
ading the new widget at step 10, either with the existing speaker and
headphone driver widgets or moving them up a step.

> and inserts a new number as you suggested for power OFF. Imo, nothing
> wrong with this approach and since I don't have all day to discuss, Magi
> will change both the sequence numbers to use the same number as
> snd_soc_dapm_spk.

Right, the down sequence is fine.


More information about the Alsa-devel mailing list