Commit 2263fddc authored by John Hsu's avatar John Hsu Committed by Mark Brown

ASoC: nau8825: lock longer to avoid playback pop upon resume

There is an issue about pop noise in NAU88L25 as follows.
Issue 54078: Chell_headphone pop back from S3
(1)Play directly to hw, bypassing CRAS:
sox -b 16 -n -t alsa hw:0,0 synth sine 200 sine 200
(2)Close lid or powerd_dbus_suspend, then press a key to resume.
(3)no audio after resume
(4)Audio will be back after close then reopen the pcm device.

After verification, we find one defect is that semaphone lock is not
long enough and expired. In this situation, the playback comes back
early but pauses a while to wait for the crosstalk detection done.
But the detection spends too much time and lock time is up. Therefore,
the playback and jack detection sequence interfere to each other.
That breaks sequence and makes noise. The driver extends the lock
time for the issue.
Signed-off-by: default avatarJohn Hsu <KCHSU0@nuvoton.com>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent aee02c75
...@@ -1233,7 +1233,7 @@ static int nau8825_hw_params(struct snd_pcm_substream *substream, ...@@ -1233,7 +1233,7 @@ static int nau8825_hw_params(struct snd_pcm_substream *substream,
struct nau8825 *nau8825 = snd_soc_codec_get_drvdata(codec); struct nau8825 *nau8825 = snd_soc_codec_get_drvdata(codec);
unsigned int val_len = 0, osr; unsigned int val_len = 0, osr;
nau8825_sema_acquire(nau8825, 2 * HZ); nau8825_sema_acquire(nau8825, 3 * HZ);
/* CLK_DAC or CLK_ADC = OSR * FS /* CLK_DAC or CLK_ADC = OSR * FS
* DAC or ADC clock frequency is defined as Over Sampling Rate (OSR) * DAC or ADC clock frequency is defined as Over Sampling Rate (OSR)
...@@ -1293,7 +1293,7 @@ static int nau8825_set_dai_fmt(struct snd_soc_dai *codec_dai, unsigned int fmt) ...@@ -1293,7 +1293,7 @@ static int nau8825_set_dai_fmt(struct snd_soc_dai *codec_dai, unsigned int fmt)
struct nau8825 *nau8825 = snd_soc_codec_get_drvdata(codec); struct nau8825 *nau8825 = snd_soc_codec_get_drvdata(codec);
unsigned int ctrl1_val = 0, ctrl2_val = 0; unsigned int ctrl1_val = 0, ctrl2_val = 0;
nau8825_sema_acquire(nau8825, 2 * HZ); nau8825_sema_acquire(nau8825, 3 * HZ);
switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) { switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) {
case SND_SOC_DAIFMT_CBM_CFM: case SND_SOC_DAIFMT_CBM_CFM:
...@@ -2121,7 +2121,7 @@ static int nau8825_configure_sysclk(struct nau8825 *nau8825, int clk_id, ...@@ -2121,7 +2121,7 @@ static int nau8825_configure_sysclk(struct nau8825 *nau8825, int clk_id,
* fered by cross talk process, the driver make the playback * fered by cross talk process, the driver make the playback
* preparation halted until cross talk process finish. * preparation halted until cross talk process finish.
*/ */
nau8825_sema_acquire(nau8825, 2 * HZ); nau8825_sema_acquire(nau8825, 3 * HZ);
nau8825_configure_mclk_as_sysclk(regmap); nau8825_configure_mclk_as_sysclk(regmap);
/* MCLK not changed by clock tree */ /* MCLK not changed by clock tree */
regmap_update_bits(regmap, NAU8825_REG_CLK_DIVIDER, regmap_update_bits(regmap, NAU8825_REG_CLK_DIVIDER,
...@@ -2169,7 +2169,7 @@ static int nau8825_configure_sysclk(struct nau8825 *nau8825, int clk_id, ...@@ -2169,7 +2169,7 @@ static int nau8825_configure_sysclk(struct nau8825 *nau8825, int clk_id,
* fered by cross talk process, the driver make the playback * fered by cross talk process, the driver make the playback
* preparation halted until cross talk process finish. * preparation halted until cross talk process finish.
*/ */
nau8825_sema_acquire(nau8825, 2 * HZ); nau8825_sema_acquire(nau8825, 3 * HZ);
/* Higher FLL reference input frequency can only set lower /* Higher FLL reference input frequency can only set lower
* gain error, such as 0000 for input reference from MCLK * gain error, such as 0000 for input reference from MCLK
* 12.288Mhz. * 12.288Mhz.
...@@ -2191,7 +2191,7 @@ static int nau8825_configure_sysclk(struct nau8825 *nau8825, int clk_id, ...@@ -2191,7 +2191,7 @@ static int nau8825_configure_sysclk(struct nau8825 *nau8825, int clk_id,
* fered by cross talk process, the driver make the playback * fered by cross talk process, the driver make the playback
* preparation halted until cross talk process finish. * preparation halted until cross talk process finish.
*/ */
nau8825_sema_acquire(nau8825, 2 * HZ); nau8825_sema_acquire(nau8825, 3 * HZ);
/* If FLL reference input is from low frequency source, /* If FLL reference input is from low frequency source,
* higher error gain can apply such as 0xf which has * higher error gain can apply such as 0xf which has
* the most sensitive gain error correction threshold, * the most sensitive gain error correction threshold,
...@@ -2217,7 +2217,7 @@ static int nau8825_configure_sysclk(struct nau8825 *nau8825, int clk_id, ...@@ -2217,7 +2217,7 @@ static int nau8825_configure_sysclk(struct nau8825 *nau8825, int clk_id,
* fered by cross talk process, the driver make the playback * fered by cross talk process, the driver make the playback
* preparation halted until cross talk process finish. * preparation halted until cross talk process finish.
*/ */
nau8825_sema_acquire(nau8825, 2 * HZ); nau8825_sema_acquire(nau8825, 3 * HZ);
/* If FLL reference input is from low frequency source, /* If FLL reference input is from low frequency source,
* higher error gain can apply such as 0xf which has * higher error gain can apply such as 0xf which has
* the most sensitive gain error correction threshold, * the most sensitive gain error correction threshold,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment