Commit 18562fc3 authored by Chris Morgan's avatar Chris Morgan Committed by Mark Brown

ASoC: es8328: Use rounded rate for es8328_set_sysclk()

I have a board (RK3588 based) that sets the sysclk to 12287999. The
es8328 driver fails to match this to the 12288000 rate and fails to
load. Allow the rate comparison to work if the frequency is within
100hz by dividing it by 100 and rounding it, then multiplying it back
by 100.

Note the 100hz value was chosen arbitrarily by me, but it has only
been tested with a 1hz difference.
Signed-off-by: default avatarChris Morgan <macromorgan@hotmail.com>
Link: https://lore.kernel.org/r/20231020171539.65513-1-macroalpha82@gmail.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent f1c40686
...@@ -556,8 +556,15 @@ static int es8328_set_sysclk(struct snd_soc_dai *codec_dai, ...@@ -556,8 +556,15 @@ static int es8328_set_sysclk(struct snd_soc_dai *codec_dai,
struct snd_soc_component *component = codec_dai->component; struct snd_soc_component *component = codec_dai->component;
struct es8328_priv *es8328 = snd_soc_component_get_drvdata(component); struct es8328_priv *es8328 = snd_soc_component_get_drvdata(component);
int mclkdiv2 = 0; int mclkdiv2 = 0;
unsigned int round_freq;
switch (freq) { /*
* Allow a small tolerance for frequencies within 100hz. Note
* this value is chosen arbitrarily.
*/
round_freq = DIV_ROUND_CLOSEST(freq, 100) * 100;
switch (round_freq) {
case 0: case 0:
es8328->sysclk_constraints = NULL; es8328->sysclk_constraints = NULL;
es8328->mclk_ratios = NULL; es8328->mclk_ratios = NULL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment