ASoC: sun8i-codec: Add a comment on the LRCK inversion
authorMaxime Ripard <maxime.ripard@free-electrons.com>
Thu, 9 Nov 2017 09:40:46 +0000 (10:40 +0100)
committerMark Brown <broonie@kernel.org>
Thu, 9 Nov 2017 11:41:51 +0000 (11:41 +0000)
The current code might be a bit intriguing without having experienced the
issue before, and might come up as a mistake.

Make explicit what's going on by adding a comment.

Signed-off-by: Maxime Ripard <maxime.ripard@free-electrons.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/sunxi/sun8i-codec.c

index c2ceca485d6a0f06be60bd0cd15fee296bb9c6bb..b3329692e3dc05636fb01c61a751efa62d52216c 100644 (file)
@@ -197,6 +197,17 @@ static int sun8i_set_fmt(struct snd_soc_dai *dai, unsigned int fmt)
        regmap_update_bits(scodec->regmap, SUN8I_AIF1CLK_CTRL,
                           BIT(SUN8I_AIF1CLK_CTRL_AIF1_BCLK_INV),
                           value << SUN8I_AIF1CLK_CTRL_AIF1_BCLK_INV);
+
+       /*
+        * It appears that the DAI and the codec don't share the same
+        * polarity for the LRCK signal when they mean 'normal' and
+        * 'inverted' in the datasheet.
+        *
+        * Since the DAI here is our regular i2s driver that have been
+        * tested with way more codecs than just this one, it means
+        * that the codec probably gets it backward, and we have to
+        * invert the value here.
+        */
        regmap_update_bits(scodec->regmap, SUN8I_AIF1CLK_CTRL,
                           BIT(SUN8I_AIF1CLK_CTRL_AIF1_LRCK_INV),
                           !value << SUN8I_AIF1CLK_CTRL_AIF1_LRCK_INV);