ASoC: stm32: i2s: fix dma configuration
authorOlivier Moysan <olivier.moysan@st.com>
Tue, 26 Feb 2019 13:51:07 +0000 (14:51 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 5 Dec 2019 14:38:33 +0000 (15:38 +0100)
commit 1ac2bd16448997d9ec01922423486e1e85535eda upstream.

DMA configuration is not balanced on start/stop.
Move DMA configuration to trigger callback.

Signed-off-by: Olivier Moysan <olivier.moysan@st.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
sound/soc/stm/stm32_i2s.c

index 6d0bf78d114d0da74f5b61f5c576c12483d562d9..449bb7049a281b6a5edd22d997ae0611f8bbcce1 100644 (file)
@@ -488,7 +488,7 @@ static int stm32_i2s_configure(struct snd_soc_dai *cpu_dai,
 {
        struct stm32_i2s_data *i2s = snd_soc_dai_get_drvdata(cpu_dai);
        int format = params_width(params);
-       u32 cfgr, cfgr_mask, cfg1, cfg1_mask;
+       u32 cfgr, cfgr_mask, cfg1;
        unsigned int fthlv;
        int ret;
 
@@ -529,15 +529,11 @@ static int stm32_i2s_configure(struct snd_soc_dai *cpu_dai,
        if (ret < 0)
                return ret;
 
-       cfg1 = I2S_CFG1_RXDMAEN | I2S_CFG1_TXDMAEN;
-       cfg1_mask = cfg1;
-
        fthlv = STM32_I2S_FIFO_SIZE * I2S_FIFO_TH_ONE_QUARTER / 4;
-       cfg1 |= I2S_CFG1_FTHVL_SET(fthlv - 1);
-       cfg1_mask |= I2S_CFG1_FTHVL_MASK;
+       cfg1 = I2S_CFG1_FTHVL_SET(fthlv - 1);
 
        return regmap_update_bits(i2s->regmap, STM32_I2S_CFG1_REG,
-                                 cfg1_mask, cfg1);
+                                 I2S_CFG1_FTHVL_MASK, cfg1);
 }
 
 static int stm32_i2s_startup(struct snd_pcm_substream *substream,
@@ -589,6 +585,10 @@ static int stm32_i2s_trigger(struct snd_pcm_substream *substream, int cmd,
                /* Enable i2s */
                dev_dbg(cpu_dai->dev, "start I2S\n");
 
+               cfg1_mask = I2S_CFG1_RXDMAEN | I2S_CFG1_TXDMAEN;
+               regmap_update_bits(i2s->regmap, STM32_I2S_CFG1_REG,
+                                  cfg1_mask, cfg1_mask);
+
                ret = regmap_update_bits(i2s->regmap, STM32_I2S_CR1_REG,
                                         I2S_CR1_SPE, I2S_CR1_SPE);
                if (ret < 0) {