ASoC: cs35l32: Simplify implementation of cs35l32_codec_set_sysclk
authorAxel Lin <axel.lin@ingics.com>
Thu, 28 Aug 2014 08:27:56 +0000 (16:27 +0800)
committerMark Brown <broonie@linaro.org>
Thu, 28 Aug 2014 18:14:18 +0000 (19:14 +0100)
Use single snd_soc_update_bits() call to update the register bits.

Signed-off-by: Axel Lin <axel.lin@ingics.com>
Tested-by: Brian Austin <brian.austin@cirrus.com>
Acked-by: Brian Austin <brian.austin@cirrus.com>
Signed-off-by: Mark Brown <broonie@linaro.org>
sound/soc/codecs/cs35l32.c

index b32d7a9d0c0fbead8352674291540f20abb0d618..76f628bd7f2b00a8f0c56990ed4615ca8115e19f 100644 (file)
@@ -242,41 +242,27 @@ static struct snd_soc_dai_driver cs35l32_dai[] = {
 static int cs35l32_codec_set_sysclk(struct snd_soc_codec *codec,
                              int clk_id, int source, unsigned int freq, int dir)
 {
+       unsigned int val;
 
        switch (freq) {
        case 6000000:
-               snd_soc_update_bits(codec, CS35L32_CLK_CTL,
-                                   CS35L32_MCLK_DIV2_MASK, 0);
-               snd_soc_update_bits(codec, CS35L32_CLK_CTL,
-                                   CS35L32_MCLK_RATIO_MASK,
-                                       CS35L32_MCLK_RATIO);
+               val = CS35L32_MCLK_RATIO;
                break;
        case 12000000:
-               snd_soc_update_bits(codec, CS35L32_CLK_CTL,
-                                   CS35L32_MCLK_DIV2_MASK,
-                                       CS35L32_MCLK_DIV2_MASK);
-               snd_soc_update_bits(codec, CS35L32_CLK_CTL,
-                                   CS35L32_MCLK_RATIO_MASK,
-                                       CS35L32_MCLK_RATIO);
+               val = CS35L32_MCLK_DIV2_MASK | CS35L32_MCLK_RATIO;
                break;
        case 6144000:
-               snd_soc_update_bits(codec, CS35L32_CLK_CTL,
-                                   CS35L32_MCLK_DIV2_MASK, 0);
-               snd_soc_update_bits(codec, CS35L32_CLK_CTL,
-                                   CS35L32_MCLK_RATIO_MASK, 0);
+               val = 0;
                break;
        case 12288000:
-               snd_soc_update_bits(codec, CS35L32_CLK_CTL,
-                                   CS35L32_MCLK_DIV2_MASK,
-                                       CS35L32_MCLK_DIV2_MASK);
-               snd_soc_update_bits(codec, CS35L32_CLK_CTL,
-                                   CS35L32_MCLK_RATIO_MASK, 0);
+               val = CS35L32_MCLK_DIV2_MASK;
                break;
        default:
                return -EINVAL;
        }
 
-       return 0;
+       return snd_soc_update_bits(codec, CS35L32_CLK_CTL,
+                       CS35L32_MCLK_DIV2_MASK | CS35L32_MCLK_RATIO_MASK, val);
 }
 
 static struct snd_soc_codec_driver soc_codec_dev_cs35l32 = {