Patch "ASoC: fsl_spdif: Fix unexpected interrupt after suspend" has been added to the 5.13-stable tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This is a note to let you know that I've just added the patch titled

    ASoC: fsl_spdif: Fix unexpected interrupt after suspend

to the 5.13-stable tree which can be found at:
    http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     asoc-fsl_spdif-fix-unexpected-interrupt-after-suspen.patch
and it can be found in the queue-5.13 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <stable@xxxxxxxxxxxxxxx> know about it.



commit 8bca0757bc665582879e3709eb9f04b9916d7318
Author: Shengjiu Wang <shengjiu.wang@xxxxxxx>
Date:   Tue Jun 22 20:31:24 2021 +0800

    ASoC: fsl_spdif: Fix unexpected interrupt after suspend
    
    [ Upstream commit a7a0a2feb957e446b2bcf732f245ba04fc8b6314 ]
    
    When system enter suspend, the machine driver suspend callback
    function will be called, then the cpu driver trigger callback
    (SNDRV_PCM_TRIGGER_SUSPEND) be called, it would disable the
    interrupt.
    
    But the machine driver suspend and cpu dai driver suspend order
    maybe changed, the cpu dai driver's suspend callback is called before
    machine driver's suppend callback, then the interrupt is not cleared
    successfully in trigger callback.
    
    So need to clear interrupts in cpu dai driver's suspend callback
    to avoid such issue.
    
    Fixes: 9cb2b3796e08 ("ASoC: fsl_spdif: Add pm runtime function")
    Signed-off-by: Shengjiu Wang <shengjiu.wang@xxxxxxx>
    Reviewed-by: Fabio Estevam <festevam@xxxxxxxxx>
    Link: https://lore.kernel.org/r/1624365084-7934-1-git-send-email-shengjiu.wang@xxxxxxx
    Signed-off-by: Mark Brown <broonie@xxxxxxxxxx>
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/sound/soc/fsl/fsl_spdif.c b/sound/soc/fsl/fsl_spdif.c
index 5636837eb511..53499bc71fa9 100644
--- a/sound/soc/fsl/fsl_spdif.c
+++ b/sound/soc/fsl/fsl_spdif.c
@@ -1404,6 +1404,9 @@ static int fsl_spdif_runtime_suspend(struct device *dev)
 	struct fsl_spdif_priv *spdif_priv = dev_get_drvdata(dev);
 	int i;
 
+	/* Disable all the interrupts */
+	regmap_update_bits(spdif_priv->regmap, REG_SPDIF_SIE, 0xffffff, 0);
+
 	regmap_read(spdif_priv->regmap, REG_SPDIF_SRPC,
 			&spdif_priv->regcache_srpc);
 	regcache_cache_only(spdif_priv->regmap, true);



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux