Re: [PATCH v2 2/2] ASoC: fsl: imx-wm8962: Grant hw_params/free()permission to control FLL

From: Nicolin Chen
Date: Tue Dec 10 2013 - 05:32:24 EST


On Tue, Dec 10, 2013 at 01:18:42PM +0800, Nicolin Chen wrote:
> On Mon, Dec 09, 2013 at 05:56:40PM +0000, Mark Brown wrote:
> > On Fri, Dec 06, 2013 at 11:38:29PM +0800, Nicolin Chen wrote:
> >
> > > +static int imx_hifi_hw_free(struct snd_pcm_substream *substream)
> > > +{
> > > + struct snd_soc_pcm_runtime *rtd = substream->private_data;
> > > + struct snd_soc_dai *codec_dai = rtd->codec_dai;
> > > +
> > > + /* Don't diable FLL if still having multiple substreams running */
> > > + if (codec_dai->active != 1)
> > > + return 0;
> > > +
> > > + return imx_wm8962_disable_fll(codec_dai);
> >
> > This will still disable the FLL if there's an analogue bypass path
> > active. I'd suggest changing enable() and disable() to reference count.
>
> I was expecting this would disable it for further reconfiguration. But it
> seems I should also considerate the case using bypass path and normal PCM
> playback simultaneously, which looks a bit complex.

Hmm...Sorry for asking a stupid question that how to test bypass path with
WM8962? I've tried some amixer commands to enable the bypass-path switches.
But we still need to power the Codec up like using arecord or aplay to call
wm8962_resume() and DAPM-related, right?

Sir, could you please share a simple flow for user space so that I can test
and make the patch more comprehensive?

Thank you,
Nicolin Chen

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/