ASoC: kirkwood-i2s: Handle mute/unmute playback/record
The controller has mute/unmute capability and some bootloader may mute them at boot. If it's not handled, all things will seem to be working but no sound will come out of the speaker/headphone. Signed-off-by: Arnaud Patard <arnaud.patard@rtp-net.org> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
This commit is contained in:
parent
dfe4c93627
commit
b424ec9533
@ -193,7 +193,8 @@ static int kirkwood_i2s_play_trigger(struct snd_pcm_substream *substream,
|
|||||||
/* configure audio & enable i2s playback */
|
/* configure audio & enable i2s playback */
|
||||||
value = readl(priv->io + KIRKWOOD_PLAYCTL);
|
value = readl(priv->io + KIRKWOOD_PLAYCTL);
|
||||||
value &= ~KIRKWOOD_PLAYCTL_BURST_MASK;
|
value &= ~KIRKWOOD_PLAYCTL_BURST_MASK;
|
||||||
value &= ~(KIRKWOOD_PLAYCTL_PAUSE|KIRKWOOD_PLAYCTL_SPDIF_EN);
|
value &= ~(KIRKWOOD_PLAYCTL_PAUSE | KIRKWOOD_PLAYCTL_I2S_MUTE
|
||||||
|
| KIRKWOOD_PLAYCTL_SPDIF_EN);
|
||||||
|
|
||||||
if (priv->burst == 32)
|
if (priv->burst == 32)
|
||||||
value |= KIRKWOOD_PLAYCTL_BURST_32;
|
value |= KIRKWOOD_PLAYCTL_BURST_32;
|
||||||
@ -206,7 +207,7 @@ static int kirkwood_i2s_play_trigger(struct snd_pcm_substream *substream,
|
|||||||
case SNDRV_PCM_TRIGGER_STOP:
|
case SNDRV_PCM_TRIGGER_STOP:
|
||||||
/* stop audio, disable interrupts */
|
/* stop audio, disable interrupts */
|
||||||
value = readl(priv->io + KIRKWOOD_PLAYCTL);
|
value = readl(priv->io + KIRKWOOD_PLAYCTL);
|
||||||
value |= KIRKWOOD_PLAYCTL_PAUSE;
|
value |= KIRKWOOD_PLAYCTL_PAUSE | KIRKWOOD_PLAYCTL_I2S_MUTE;
|
||||||
writel(value, priv->io + KIRKWOOD_PLAYCTL);
|
writel(value, priv->io + KIRKWOOD_PLAYCTL);
|
||||||
|
|
||||||
value = readl(priv->io + KIRKWOOD_INT_MASK);
|
value = readl(priv->io + KIRKWOOD_INT_MASK);
|
||||||
@ -222,14 +223,14 @@ static int kirkwood_i2s_play_trigger(struct snd_pcm_substream *substream,
|
|||||||
case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
|
case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
|
||||||
case SNDRV_PCM_TRIGGER_SUSPEND:
|
case SNDRV_PCM_TRIGGER_SUSPEND:
|
||||||
value = readl(priv->io + KIRKWOOD_PLAYCTL);
|
value = readl(priv->io + KIRKWOOD_PLAYCTL);
|
||||||
value |= KIRKWOOD_PLAYCTL_PAUSE;
|
value |= KIRKWOOD_PLAYCTL_PAUSE | KIRKWOOD_PLAYCTL_I2S_MUTE;
|
||||||
writel(value, priv->io + KIRKWOOD_PLAYCTL);
|
writel(value, priv->io + KIRKWOOD_PLAYCTL);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SNDRV_PCM_TRIGGER_RESUME:
|
case SNDRV_PCM_TRIGGER_RESUME:
|
||||||
case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
|
case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
|
||||||
value = readl(priv->io + KIRKWOOD_PLAYCTL);
|
value = readl(priv->io + KIRKWOOD_PLAYCTL);
|
||||||
value &= ~KIRKWOOD_PLAYCTL_PAUSE;
|
value &= ~(KIRKWOOD_PLAYCTL_PAUSE | KIRKWOOD_PLAYCTL_I2S_MUTE);
|
||||||
writel(value, priv->io + KIRKWOOD_PLAYCTL);
|
writel(value, priv->io + KIRKWOOD_PLAYCTL);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -262,7 +263,8 @@ static int kirkwood_i2s_rec_trigger(struct snd_pcm_substream *substream,
|
|||||||
value = readl(priv->io + KIRKWOOD_RECCTL);
|
value = readl(priv->io + KIRKWOOD_RECCTL);
|
||||||
value &= ~KIRKWOOD_RECCTL_BURST_MASK;
|
value &= ~KIRKWOOD_RECCTL_BURST_MASK;
|
||||||
value &= ~KIRKWOOD_RECCTL_MONO;
|
value &= ~KIRKWOOD_RECCTL_MONO;
|
||||||
value &= ~(KIRKWOOD_RECCTL_PAUSE | KIRKWOOD_RECCTL_SPDIF_EN);
|
value &= ~(KIRKWOOD_RECCTL_PAUSE | KIRKWOOD_RECCTL_MUTE
|
||||||
|
| KIRKWOOD_RECCTL_SPDIF_EN);
|
||||||
|
|
||||||
if (priv->burst == 32)
|
if (priv->burst == 32)
|
||||||
value |= KIRKWOOD_RECCTL_BURST_32;
|
value |= KIRKWOOD_RECCTL_BURST_32;
|
||||||
@ -276,7 +278,7 @@ static int kirkwood_i2s_rec_trigger(struct snd_pcm_substream *substream,
|
|||||||
case SNDRV_PCM_TRIGGER_STOP:
|
case SNDRV_PCM_TRIGGER_STOP:
|
||||||
/* stop audio, disable interrupts */
|
/* stop audio, disable interrupts */
|
||||||
value = readl(priv->io + KIRKWOOD_RECCTL);
|
value = readl(priv->io + KIRKWOOD_RECCTL);
|
||||||
value |= KIRKWOOD_RECCTL_PAUSE;
|
value |= KIRKWOOD_RECCTL_PAUSE | KIRKWOOD_RECCTL_MUTE;
|
||||||
writel(value, priv->io + KIRKWOOD_RECCTL);
|
writel(value, priv->io + KIRKWOOD_RECCTL);
|
||||||
|
|
||||||
value = readl(priv->io + KIRKWOOD_INT_MASK);
|
value = readl(priv->io + KIRKWOOD_INT_MASK);
|
||||||
@ -292,14 +294,14 @@ static int kirkwood_i2s_rec_trigger(struct snd_pcm_substream *substream,
|
|||||||
case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
|
case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
|
||||||
case SNDRV_PCM_TRIGGER_SUSPEND:
|
case SNDRV_PCM_TRIGGER_SUSPEND:
|
||||||
value = readl(priv->io + KIRKWOOD_RECCTL);
|
value = readl(priv->io + KIRKWOOD_RECCTL);
|
||||||
value |= KIRKWOOD_RECCTL_PAUSE;
|
value |= KIRKWOOD_RECCTL_PAUSE | KIRKWOOD_RECCTL_MUTE;
|
||||||
writel(value, priv->io + KIRKWOOD_RECCTL);
|
writel(value, priv->io + KIRKWOOD_RECCTL);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SNDRV_PCM_TRIGGER_RESUME:
|
case SNDRV_PCM_TRIGGER_RESUME:
|
||||||
case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
|
case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
|
||||||
value = readl(priv->io + KIRKWOOD_RECCTL);
|
value = readl(priv->io + KIRKWOOD_RECCTL);
|
||||||
value &= ~KIRKWOOD_RECCTL_PAUSE;
|
value &= ~(KIRKWOOD_RECCTL_PAUSE | KIRKWOOD_RECCTL_MUTE);
|
||||||
writel(value, priv->io + KIRKWOOD_RECCTL);
|
writel(value, priv->io + KIRKWOOD_RECCTL);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user