aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sound/soc/sunxi/sun8i-codec.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/sound/soc/sunxi/sun8i-codec.c b/sound/soc/sunxi/sun8i-codec.c
index c2ceca485d6a..b3329692e3dc 100644
--- a/sound/soc/sunxi/sun8i-codec.c
+++ b/sound/soc/sunxi/sun8i-codec.c
@@ -197,6 +197,17 @@ static int sun8i_set_fmt(struct snd_soc_dai *dai, unsigned int fmt)
197 regmap_update_bits(scodec->regmap, SUN8I_AIF1CLK_CTRL, 197 regmap_update_bits(scodec->regmap, SUN8I_AIF1CLK_CTRL,
198 BIT(SUN8I_AIF1CLK_CTRL_AIF1_BCLK_INV), 198 BIT(SUN8I_AIF1CLK_CTRL_AIF1_BCLK_INV),
199 value << SUN8I_AIF1CLK_CTRL_AIF1_BCLK_INV); 199 value << SUN8I_AIF1CLK_CTRL_AIF1_BCLK_INV);
200
201 /*
202 * It appears that the DAI and the codec don't share the same
203 * polarity for the LRCK signal when they mean 'normal' and
204 * 'inverted' in the datasheet.
205 *
206 * Since the DAI here is our regular i2s driver that have been
207 * tested with way more codecs than just this one, it means
208 * that the codec probably gets it backward, and we have to
209 * invert the value here.
210 */
200 regmap_update_bits(scodec->regmap, SUN8I_AIF1CLK_CTRL, 211 regmap_update_bits(scodec->regmap, SUN8I_AIF1CLK_CTRL,
201 BIT(SUN8I_AIF1CLK_CTRL_AIF1_LRCK_INV), 212 BIT(SUN8I_AIF1CLK_CTRL_AIF1_LRCK_INV),
202 !value << SUN8I_AIF1CLK_CTRL_AIF1_LRCK_INV); 213 !value << SUN8I_AIF1CLK_CTRL_AIF1_LRCK_INV);