]> git.proxmox.com Git - mirror_ubuntu-focal-kernel.git/commit
ASoC: wm8960: Fix wrong bclk and lrclk with pll enabled for some chips
authorShengjiu Wang <shengjiu.wang@nxp.com>
Fri, 19 Mar 2021 10:48:46 +0000 (18:48 +0800)
committerStefan Bader <stefan.bader@canonical.com>
Tue, 4 May 2021 14:08:49 +0000 (16:08 +0200)
commiteadd7d205ac5aa5bf7691639b869ca0d5b2cb402
treeaed65d74d5606ff9c82a1a49f015de486ecc3d4e
parent06e2cbf2492e874d5901229d9fddaadf08b5f383
ASoC: wm8960: Fix wrong bclk and lrclk with pll enabled for some chips

BugLink: https://bugs.launchpad.net/bugs/1926489
[ Upstream commit 16b82e75c15a7dbd564ea3654f3feb61df9e1e6f ]

The input MCLK is 12.288MHz, the desired output sysclk is 11.2896MHz
and sample rate is 44100Hz, with the configuration pllprescale=2,
postscale=sysclkdiv=1, some chip may have wrong bclk
and lrclk output with pll enabled in master mode, but with the
configuration pllprescale=1, postscale=2, the output clock is correct.

>From Datasheet, the PLL performs best when f2 is between
90MHz and 100MHz when the desired sysclk output is 11.2896MHz
or 12.288MHz, so sysclkdiv = 2 (f2/8) is the best choice.

So search available sysclk_divs from 2 to 1 other than from 1 to 2.

Fixes: 84fdc00d519f ("ASoC: codec: wm9860: Refactor PLL out freq search")
Signed-off-by: Shengjiu Wang <shengjiu.wang@nxp.com>
Acked-by: Charles Keepax <ckeepax@opensource.cirrus.com>
Link: https://lore.kernel.org/r/1616150926-22892-1-git-send-email-shengjiu.wang@nxp.com
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
sound/soc/codecs/wm8960.c