[alsa-devel] [PATCH] ASoC: max98357a: Fix speaker pop when starting playback
Ezequiel Garcia
ezequiel at collabora.co.uk
Thu Mar 22 05:00:49 CET 2018
Hi Mark,
Thanks for reviewing this so quickly.
On Thu, 2018-03-22 at 09:54 +0800, Mark Brown wrote:
> On Wed, Mar 21, 2018 at 07:30:15PM -0300, Ezequiel Garcia wrote:
>
> > +- sdmode-delay : specify a delay time for SD_MODE pin. According
> > + to the DAC datasheet, if LRCLK is removed while BCLK is
> > present,
> > + the DAC output can cause loud pop/crack noises. This
> > property
> > + specifies a delay for the SD_MODE pin assert, required to
> > + eliminate the noise.
>
> Why is this configurable? This sounds like something entirely within
> the digital domain of the device rather than something that depends
> on
> board configuration and it's hard to see how someone would configure
> this.
>
The amount of delay needed seems specific to the CPU DAI,
not specific to the DAC. The CPU DAIs or the machine
could specify this as a parameter, but I can't don't see how.
Perhaps it could be a driver parameter?
> > +static void max98357a_enable_sdmode_work(struct work_struct *work)
> > +{
> > + struct max98357a_priv *max98357a = container_of(work,
> > + struct max98357a_priv, enable_sdmode_work.work);
> > + unsigned long flags;
> > +
> > + spin_lock_irqsave(&max98357a->sdmode_lock, flags);
> > + gpiod_set_value(max98357a->sdmode, max98357a-
> > >sdmode_enabled);
> > + spin_unlock_irqrestore(&max98357a->sdmode_lock, flags);
> > +}
>
> What is this lock supposed to accomplish? We perform a single action
> under the lock which itself has internal locking, it's not going to
> have
> any meaningful effect.
I am under the impression it removes the race condition
between the gpiod_set_value() happening in the different
contexts.
Thanks,
Eze
More information about the Alsa-devel
mailing list